最新要闻
- 民间大神用虚幻5自制《原神》 :这视觉效果爱了
- 【环球报资讯】曾经缔造玛雅文明!为什么玉米的产量世界第一?
- 深扒《阿凡达2》背后的故事:才是真的“细思恐极”!
- 【全球快播报】蔚来CEO李斌回应数据泄露问题 绝不会与不法行为妥协
- 全球热推荐:我去大疆新总部逛了逛:评测了有史以来最大的“产品”
- 每日焦点!梅西晒怀抱大力神杯入睡照!淘宝同款奖杯被抢光
- 当前热议!神似梅西男子成网红 被民众围堵合影:这也太像了
- 分析师称《阿凡达2》难以回本:卡梅隆标准定太高了
- 2199元 掌阅Smart Air Pro电纸书上架:8寸大屏、300PPI显示
- 天天即时:怀旧情怀拉满:宾得宣布将开发新款胶片相机
- 阿根廷夺冠“拯救”伊利 但“奶茅”光环渐黯
- 环球快讯:一加宣布与OPPO服务融合:12月底全面加入OPPO售后服务系统
- 东北将迎今冬以来最强降雪:持续时间最长、范围最广
- PCIe 5.0 SSD终于满血了!读写都是14GB/s、容量8TB
- 热消息:蔚来遭遇225万美元数据勒索 官方声明
- 当前讯息:铃木“大G”!吉姆尼五门版无伪谍照:最多能塞进7个人
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
当前快讯:第一百一十六篇: JavaScript理解对象
好家伙,本篇为《JS高级程序设计》第八章“对象、类与面向对象编程”学习笔记
(资料图)
1.关于对象
ECMA-262将对象定义为一组属性的无序集合。严格来说,这意味着对象就是一组没有特定顺序的值。
对象的每个属性或方法都由一个名称来标识,这个名称映射到一个值。正因为如此(以及其他还未讨论的原因),可以把
ECMAScript的对象想象成一张散列表,其中的内容就是一组名/值对,值可以是数据或者函数。
简单使用一下
let object =new Object();object.name ="panghu";object.age ="20";object.job ="student";object.getName = function(){ console.log(this.name)};
看图:
也可以这样写,在这种字面量中,等号变为了冒号,分号变为了逗号
(显然第二种更美观,直接)
let object = { name: "panghu", age: "20", job: "student", getName() { console.log(this.name) }}object.getName();
看图:
2.属性类型
ECMA-262使用一些内部特性来描述属性的特征。这些特性是由为JavaScript实现引擎的规范定义的。
因此,开发者不能在JavaScript中直接访问这些特性。
为了将某个特性标识为内部特性,规范会用两个中括号把特性的名称括起来,比如[[Enumerable]]。
属性分两种,数据属性和访问器属性。
2.1.1.数据属性数据属性包含一个保存数据值的位置。值会从这个位置读取,也会写入到这个位置。
数据属性有4个特性描述它们的行为。
(是否可以修改"数据属性",是否可遍历,值是否可修改,值 就是这个四个)
□[[Configurable]]:表示属性是否可以通过delete 删除并重新定义,是否可以修改它的特性,以及是否可以把它改为访问器属性。
默认情况下,所有直接定义在对象上的属性的这个特性都是true,如前面的例子所示。□[[Enumerable]]:表示属性是否可以通过for-in循环返回。
默认情况下,所有直接定义在对象上的属性的这个特性都是true,如前面的例子所示。□[[writable]]:表示属性的值是否可以被修改。
默认情况下,所有直接定义在对象上的属性的这个特性都是true,如前面的例子所示。□[[Value]]:包含属性实际的值。这就是前面提到的那个读取和写入属性值的位置。
这个特性的默认值为undefined。
2.1.2.object.defineProperty()方法
使用object.defineProperty()方法修改属性的默认特性
这个方法接收3个参数:要给其添加属性的对象、属性的名称和一个描述符对象。
示例:
let person ={};Object.defineProperty(person,"name",{ configurable:false, value:"panghu"})console.log(person.name);Object.defineProperty(person,"name",{ configurable:false, value:"xiaofu"})console.log(person.name);
此处,将configurable属性改为false后,不可再修改数据属性,
(writable属性同理,writable改为false后,不可再修改"值"的属性)
(过河拆桥了属于是)
2.2.访问器属性
访问器属性不包含数据值。(就像它的名字一样,他是用来访问的)
相反,它们包含一个获取(getter)函数和一个设置(setter)函数,不过这两个函数不是必需的。
在读取访问器属性时,会调用获取函数,这个函数的责任就是返回一个有效的值。
在写入访问器属性时,会调用设置函数并传入新值,这个函数必须决定对数据做出什么修改。访问器属性有4个特性描述它们的行为。
(联系着上面那个一起记就好了)
□[[configurable]]:表示属性是否可以通过delete 删除并重新定义,是否可以修改它的特性,以及是否可以把它改为数据属性。
默认情况下,所有直接定义在对象上的属性的这个特性都是true。□[[Enumerable]]:表示属性是否可以通过for-in循环返回。
默认情况下,所有直接定义在对象上的属性的这个特性都是true。□[[Get]]:获取函数,在读取属性时调用。默认值为undefined。□[[set]]:设置函数,在写入属性时调用。默认值为undefined。
访问器属性是不能直接定义的,必须使用Object.defineProperty()。
书本中的原例:
let book = { year_: 2017, edition: 1}Object.defineProperty(book, "year", { get() { return this.year_; }, set(newValue) { if (newValue > 2017) { //此时this指向book this.year_ = newValue; this.edition += newValue - 2017; } }});book.year = 2018;console.log(book.edition);
这是访问器属性的典型使用场景,即设置一个属性值会导致一些其他变化发生。
3.定义多个属性
我们使用Object.defineProperty()去修改某个对象的属性(数据属性或访问器属性),
那么,按照JS一贯的尿性,定义多个属性大概使用"它的复数"方法 (这个改复数我会,去y加ies)
Object.defineProperties()方法:
let person = {};Object.defineProperties(person, { name_: { value: "panghu" }, age: { value: "20" }, name: { getName() { return this.name_; }, }})console.log(person);
4.读取属性的特性
使用 Object.getOwnPropertyDescriptor()方法可以取得指定属性的属性描述符。
这个方法接收两个参数::属性所在的对象和要取得其描述符的属性名。
返回值是一个对象,对于访问器属性包含configurable、enumerable、get和 set属性,
对于数据属性包含 configurable,enumerable.writable和value属性。
(这个变复数我会,直接加s)
ECMAScript 2017 新增了 Object.getOwnPropertyDescriptors()静态方法。
这个方法实际上会在每个自有属性上调用object.getOwnPropertyDescriptor()并在一个新对象中返回它们。
两个方法放同一个例子了:
let person = {};Object.defineProperties(person, { name_: { value: "panghu" }, age: { value: "20" }, name: { get:function() { return this.name_; }, set:function(name){ this.name=name; } }})let descriptor_1 = Object.getOwnPropertyDescriptor(person,"name");let descriptor_2 = Object.getOwnPropertyDescriptors(person);console.log(descriptor_1);console.log(descriptor_2);
5.合并对象
JavaScript 开发者经常觉得“合并”(merge)两个对象很有用。
更具体地说,就是把源对象所有的本地属性一起复制到目标对象上。
有时候这种操作也被称为“混人”(mixin),因为目标对象通过混入源对象的属性得到了增强。
ECMAScript6专门为合并对象提供了object.assign()方法。
这个方法接收一个目标对象和一个或多个源对象作为参数,
然后将每个源对象中可枚举(object.propertyIsEnumerable()返回 true)和自有(Object.hasownProperty()返回true)属性复制到目标对象。
以字符串和符号为键的属性会被复制。
对每个符合条件的属性,这个方法会使用源对象上的[[Get]]取得属性的值,然后使用目标对象上的[[Set]]设置属性的值。
let book, person ,result;book ={};person ={ id:"999"};result = Object.assign(book,person);console.log(result);console.log(book);
6.增强的对象语法
6.1.属性值的简写
两者等价
let name = "panghu";let person ={ name:name};console.log(person);
简写:
let name = "panghu";let person ={ name:name};console.log(person);
6.2.可计算属性
在引入可计算属性之前,如果想使用变量的值作为属性,
那么必须先声明对象,然后使用中括号语法来添加属性。
换句话说,不能在对象字面量中直接动态命名属性。
有了可计算属性,就可以在对象字面量中完成动态属性赋值。
中括号包围的对象属性键告诉运行时将其作为JavaScript表达式而不是字符串来求值
示例如下:
const name_key ="panghu";let person ={ [name_key]: "xiaofu",}console.log(person);
6.3.简写方法名
let person ={ name:"panghu", getName: function(){ return this.name }}person.getName();
let person ={ name:"panghu", getName(){ return this.name }}person.getName();
7.对象解构
ECMAScript6新增了对象解构语法,可以在一条语句中使用嵌套数据实现一个或多个赋值操作。
简单地说,对象解构就是使用与对象匹配的结构来实现对象属性赋值。
(简单的说,就是拆开来用)
let person = { name: "panghu", age: "20",};let { name: personName, age: personAge} = person;console.log(personName);console.log(personAge);//简写版本let { name, age} = person;console.log(name);console.log(age);
注意:undefined和null不能被解构
-
世界微资讯!Python参数解析器configparser
1 configparser介绍configparser是python自带的配置参数解析器。可以用于解析 config文件中的配置参数...
来源: 当前快讯:第一百一十六篇: JavaScript理解对象
世界微资讯!Python参数解析器configparser
民间大神用虚幻5自制《原神》 :这视觉效果爱了
【环球报资讯】曾经缔造玛雅文明!为什么玉米的产量世界第一?
深扒《阿凡达2》背后的故事:才是真的“细思恐极”!
【全球快播报】蔚来CEO李斌回应数据泄露问题 绝不会与不法行为妥协
全球热推荐:我去大疆新总部逛了逛:评测了有史以来最大的“产品”
焦点速递!Python unittest+ddt+openpyxl接口自动化
今日热讯:MAUI新生4.4-笔刷Brush
每日焦点!梅西晒怀抱大力神杯入睡照!淘宝同款奖杯被抢光
速讯:python + selenium实现gitlab全文搜索
热资讯!Codeforces 1763 F Edge Queries 题解
天天视讯!如何使用Yum History查找已安装或已删除的软件包信息
天天新消息丨混合场景
当前热议!神似梅西男子成网红 被民众围堵合影:这也太像了
分析师称《阿凡达2》难以回本:卡梅隆标准定太高了
2199元 掌阅Smart Air Pro电纸书上架:8寸大屏、300PPI显示
前端工程化Vue-cli
天天微头条丨Python unittest数据处理ddt
前端CSS Flex布局8大重难点知识,收藏起来吧
世界新消息丨django10 分页器与Form组件
【全球新要闻】FreeSWITCH学习笔记:XML配置文件
天天即时:怀旧情怀拉满:宾得宣布将开发新款胶片相机
阿根廷夺冠“拯救”伊利 但“奶茅”光环渐黯
环球快讯:一加宣布与OPPO服务融合:12月底全面加入OPPO售后服务系统
东北将迎今冬以来最强降雪:持续时间最长、范围最广
世界速递!框架第九课---ajax补充说明,多对多三种创建方式,django内置序列化组件(drf前身),ORM批量操作数据(ORM操作优化),自定义分页器,f
WPF工控组态软件之温度计
每日播报!Iceberg在袋鼠云的探索及实践
每日关注!hibernate validate工具,小心你的姿势不对
PCIe 5.0 SSD终于满血了!读写都是14GB/s、容量8TB
热消息:蔚来遭遇225万美元数据勒索 官方声明
当前讯息:铃木“大G”!吉姆尼五门版无伪谍照:最多能塞进7个人
奇迹!女子手机从26楼掉落未摔坏 真身竟是这款手机
5499元 联合创新推出新款32英寸显示器:4K MiniLED屏、144Hz高刷
“非洲之王”拥抱新技术:传音首台折叠屏手机已通过蓝牙SIG认证
天天短讯!世界北极熊之都升温过快 已危及北极熊生存:吃不上饭了
天天热资讯!深度学习炼丹-数据处理和增强
世界热门:记录--可视化大屏-用threejs撸一个3d中国地图
Python操作Excel(openpyxl)
全球热点评!Html5 canvas创意特效合集
即时看!1月1日起:澳门私家车可经港珠澳大桥出入内地
观速讯丨巡游大巴太高 梅西险些撞上电缆!他带回阿根廷的大力神杯居然是复制品
天天短讯!中国联通科技人才占比已达30% 曾发话不能再用老眼光看电信行业
空难曾致346人死亡 波音737 Max飞机延期采用最新安全标准
每日观察!广州多个外卖平台下单后配送慢 平台:员工已是全负荷工作
世界视讯!数据结构堆(Heap)&排序&二叉树
今日播报!用好这个任务管理工具,轻松躲避职场明枪暗箭
世界今日报丨彩虹女神跃长空,Go语言进阶之Go语言高性能Web框架Iris项目实战-登录与图形验证码(captcha)EP06
今日热闻!低代码:如何成为企业业务价值提升的一大利器?
热消息:Intel第二代独立显卡1年后见:要追上RTX 4070!
主页不刷新了 小红书崩了累坏网友:WiFi、流量疯狂切换
罗永浩称他的失败不是理想主义的错 是他们自己的错
世界热讯:吴京《流浪地球2》吃苹果皮:大年初一上映
世界要闻:中国移动千兆宽带用户已达2.4亿!你是其中之一吗?
安全信息流工具-中文安全RSS小程序
supervisor+gunicorn+uvicorn部署fastapi项目
天天实时:四年保质期囤货无压力!900压缩饼干8斤85元
天天热资讯!iPhone 15系列或重新划分机型组合:14 Plus太拉胯 要大改
一加11质感绝了!刘作虎给员工秀真机:围观群众都发出WOW
美国“显卡税”又推迟9个月:一旦征收 最多涨价25%
全球讯息:大无语 车主称理想L9半个月坏三次 充电口从电动变手动
天天关注:企业转型难?火山引擎数智平台提供数智升级新路径
焦点热门:Dubbo架构设计与源码解析(一) 架构设计
Redis的AOF持久化
【报资讯】防火墙功能(锐捷安全篇)
当前热文:多方安全计算(4)MPC万能积木:秘密共享
【全球时快讯】多方安全计算(3)MPC万能钥匙:混淆电路
全力推进企业数智赋能发展主线,低代码任重道远
天天要闻:linux安装stable diffusion2.0完整教程-还不会安装sd2.0?一篇文章教会你AI绘画
焦点速读:proto IDL管理工具buf使用实践
P2329 栅栏
全球观点:Xml转Java实体类对象 xml转Javabena 对象 且多级嵌套 复杂嵌套
世界动态:用Python写一个一次性计算出加减乘除的运算小程序
世界热文:实验一:获取主机信息
全球播报:MySQL-InnoDB磁盘结构
今日热议:pkg对egg项目打包
天天精选!java的final关键字
环球快报:【验证码逆向专栏】某片滑块、点选验证码逆向分析
环球热议:别再用 JWT 作为 Session 系统了,问题重重,后果很危险!
全球球精选!Osx10.14升级watchman踩坑记
时讯:二分法
用Python来写个小型购物车程序
天天观速讯丨基于 Dubbo Admin 动态进行流量隔离
赫德-德普官司以一百万美元赔偿和解
百度地图首发自研“北斗高精”技术 升级“真”车道级导航
【环球时快讯】中国版“猛禽”!长城山海炮大型皮卡实车现身:配自研3.0T、9AT
上海首张城市高级辅助驾驶地图许可来了 百度率先获批
环球快看点丨伊朗男子65厘米创吉尼斯最矮纪录:站起来才到到成人膝盖处
热门:如何基于 Spring Boot 快速开发一个 Dubbo 微服务应用
【世界时快讯】安卓抄错了?iPhone 15 Pro最新概念图:告别纯直边
当前关注:网络谣言别再传了!短视频中梅西抱的不是母亲:是阿根廷队女厨师
天天通讯!微软、谷歌之后 欧盟反垄断又对美国Meta下手:可罚款上百亿美元
每日视讯:4K游戏串流没了 NVIDIA删除使用9年的GameStream功能引用户不满
2022最后一跌!今起油价下调:加满一箱92号汽油少花19.5元
消息!苹果App Store被法国罚款100万美元:Epic CEO、扎克伯格都曾痛批
多次骂新能源!丰田再度质疑汽车全面电动化:中国品牌弯道超车
35岁本泽马宣布从法国队退役:球迷唏嘘 祝福俱乐部继续精彩
Python单元测试框架unittest
环球播报:北京等多地天空疑现震撼的火箭夜光云:原理科普