【常用语法】
//1.定义对象: var const let
var Person = {
name: '张三',
birth,//等同于birth: birth
hello() { console.log('我的名字是', this.name); }// 等同于hello: function ()...
};
//2.对象的合并assign:
2.1.添加属性*************************************
var target = { a: 1 };//合并成: {a:1, b:2, c:3},注:同名属性,则后面的属性会覆盖前面的属性。
var source1 = { b: 2 };
var source2 = { c: 3 };
.assign(target, source1, source2);
2.2.添加方法*********************************************
.assign(SomeClass.prototype, {
someMethod(arg1, arg2) {
···
},
anotherMethod() {
···
}
});
// 等同于下面的写法
SomeClass.prototype.someMethod = function (arg1, arg2) {
···
};
SomeClass.prototype.anotherMethod = function () {
···
};
2.3.克隆对象********************************************
var obj1 = {a: {b: 1}};//obj1.a.b = 2;
var obj2 = .assign({}, obj1);//克隆对象obj1,得到:obj2.a.b=2
//只能克隆原始对象自身的值,不能克隆它继承的值。
class Point {
constructor(x, y) {
.assign(this, {x, y});
}
}
//解决方案
function clone(origin) {
let originProto = .getPrototypeOf(origin);
return .assign( .create(originProto), origin);
}
2.4.合并多个对象
const merge = (target, ...sources) => .assign(target, ...sources);
const merge = (...sources) => .assign({}, ...sources);
2.5.为属性指定默认值,即2.1的扩展
const DEFAULTS = {
logLevel: 0,
outputFormat: 'html'
};
function processContent(options) {
options = .assign({}, DEFAULTS, options);
console.log(options);
// ...
}
【实践操作:】
//1.获取key value组合成数组:js ES6
var obj = {
"name" : "zh",
"age" : 22,
}
1.1.对象自身属性遍历
for(var key in obj){
console.log(key); //键名
console.log(obj[key]); //键值
//if(obj.hasOwnProperty(key))
if (obj.hasOwnProperty(key) === true) {
console.log(obj[key])
}
}
const keys = .keys(obj);
const values = .values(obj);
1.2.解构赋值
let { x, y, ...z } = { x: 1, y: 2, a: 3, b: 4 };
x // 1
y // 2
z // { a: 3, b: 4 }
1.3.扩展运算符
let z = { a: 3, b: 4 };
let n = { ...z };
n // { a: 3, b: 4 }
//2.取值判断问题
2.1.读取对象内部的某个属性,往往需要判断一下该对象是否存在
const firstName = message && message.body && message.body.user && message.body.user.firstName) || 'default';
if(firstName){
}
2.2.现在有一个提案,引入了“Null 传导运算符”
const firstName = message?.body?.user?.firstName || 'default';
if(firstName){
}
继续阅读与本文标签相同的文章
Sublime的常用插件及安装、使用和删除
JavaScript文件加载优化
-
阿里云自助注册申请的详细介绍
2026-05-19栏目: 教程
-
阿里云/万网CNAME配置的详细图文流程 新手必看教程
2026-05-19栏目: 教程
-
阿里云如何添加邮箱解析来实现收发邮件服务
2026-05-19栏目: 教程
-
怎么将个人实名认证变更为企业实名认证?
2026-05-19栏目: 教程
-
SpringBoot2 整合 Shiro 框架,实现用户权限管理
2026-05-19栏目: 教程
