当前位置: 首页 > news >正文

网站域名hk今日新闻大事件

网站域名hk,今日新闻大事件,青岛营销推广,信创网站关于proxy的精髓理解(掌握这些理解,基本对proxy的执行过程也就有了把握): 1、Proxy 用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种“元编程”(meta programming&#xff0…

关于proxy的精髓理解(掌握这些理解,基本对proxy的执行过程也就有了把握):

1、Proxy 用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种“元编程”(meta programming),即对编程语言进行编程

2、 Proxy 可以理解成,在目标对象之前架设一层“拦截”,外界对该对象的访问,都必须先通过这层拦截,因此提供了一种机制,可以对外界的访问进行过滤和改写。Proxy 这个词的原意是代理,用在这里表示由它来“代理”某些操作,可以译为“代理器”。

3、Proxy 实际上重载(overload)了点运算符,即用自己的定义覆盖了语言的原始定义

语法:

var proxy = new Proxy(target, handler);

Proxy 对象的所有用法,都是上面这种形式,不同的只是handler参数的写法。其中,new Proxy()表示生成一个Proxy实例,target参数表示所要拦截的目标对象,handler参数也是一个对象,用来定制拦截行为。

coding:

    let obj = new Proxy({},{get: function(target,propKey,receiver) {console.log(`获取的时候会被拦截`)console.log(target,propKey,receiver)return Reflect.get(target,propKey,receiver)},set: function(target,propKey,value,receiver) {console.log(`设置时被拦截`);console.log(target,propKey,value,receiver)return Reflect.set(target,propKey,value,receiver)}
})
console.log(obj) // Proxy {}obj.count = 1
// 设置时被拦截
// {} "count" 1 Proxy {}++obj.count
// 获取的时候会被拦截
// {count: 1} "count" Proxy {count: 1}
// 设置时被拦截
// {count: 1} "count" 2 Proxy {count: 1}
let porxy1 = new Proxy({},{get: function(target,propKey) {if(propKey === 'time') {return 99}return 100}
})
console.log(porxy1.age) // 100
console.log(porxy1.time) //  99
// hander没有设置任何拦截,等于直接通向原对象,没有任何拦截效果,访问proxy就等同于访问target
let target = {}
let hander = {}
let proxy2 = new Proxy(target,hander)
proxy2.name = 'xiao'
console.log(proxy2.name)  // xiao
// proxy对象是obj对象的原型,obj对象本身并没有time属性,
// 所以根据原型链,会在proxy对象上读取该属性,导致被拦截
let proxy3 = new Proxy({},{get: function(target,propKey) {return 419}
})
let obj1 = Object.create(proxy3)
console.log(obj1.name) // 419

发问,vue3的响应式为什么Object.defineProperty() 要改成Proxy,看下面:

Object.defineProperty(obj, prop, descriptor)
// 显式
Object.defineProperty(obj, "key", {enumerable: false,configurable: false,writable: false,value: "static"
})// configurable  当且仅当该属性的 configurable 键值为 true 时,
//该属性的描述符才能够被改变,同时该属性也能从对应的对象上被删除。 默认为 false。// enumerable  当且仅当该属性的 enumerable 键值为 true 时,
// 该属性才会出现在对象的枚举属性中。 默认为 false。// value该属性对应的值。可以是任何有效的 JavaScript 值(数值,对象,函数等)。
// 默认为 undefined。//writable 当且仅当该属性的 writable 键值为 true 时,属性的值,
// 也就是上面的 value,才能被赋值运算符 (en-US)改变。 默认为 false。//get 属性的 getter 函数,如果没有 getter,则为 undefined。
//当访问该属性时,会调用此函数。执行时不传入任何参数,但是会传入 this 对象(由于继承关系,
// 这里的this并不一定是定义该属性的对象)。该函数的返回值会被用作属性的值。 默认为 undefined。//set 属性的 setter 函数,如果没有 setter,则为 undefined。
// 当属性值被修改时,会调用此函数。该方法接受一个参数(也就是被赋予的新值),
// 会传入赋值时的 this 对象。 默认为 undefined。var o = {}; // 创建一个新对象
var bValue = 38;
Object.defineProperty(o, "b", {// 使用了方法名称缩写(ES2015 特性)// 下面两个缩写等价于:// get : function() { return bValue; },// set : function(newValue) { bValue = newValue; },get() { return bValue; },set(newValue) { bValue = newValue; },enumerable : true,configurable : true
});

Object.defineProperty() 就上面那几把梭,看看proxy,好几把梭,换换换

var handler = {get: function(target, name) {if (name === 'prototype') {return Object.prototype;}return 'Hello, ' + name;},apply: function(target, thisBinding, args) {return args[0];},construct: function(target, args) {return {value: args[1]};}
};var fproxy = new Proxy(function(x, y) {return x + y;
}, handler);fproxy(1, 2) // 1
new fproxy(1, 2) // {value: 2}
fproxy.prototype === Object.prototype // true
fproxy.foo === "Hello, foo" // true

对于可以设置、但没有设置拦截的操作,则直接落在目标对象上,按照原先的方式产生结果。

下面是 Proxy 支持的拦截操作一览,一共 13 种。

  1. get(target, propKey, receiver):拦截对象属性的读取,比如proxy.foo和proxy[‘foo’]。
  2. set(target, propKey, value, receiver):拦截对象属性的设置,比如proxy.foo = v或proxy[‘foo’] = v,返回一个布尔值。
  3. has(target, propKey):拦截propKey in proxy的操作,返回一个布尔值。
  4. deleteProperty(target, propKey):拦截delete proxy[propKey]的操作,返回一个布尔值。
  5. ownKeys(target):拦截Object.getOwnPropertyNames(proxy)、Object.getOwnPropertySymbols(proxy)、Object.keys(proxy)、for…in循环,返回一个数组。该方法返回目标对象所有自身的属性的属性名,而Object.keys()的返回结果仅包括目标对象自身的可遍历属性。
  6. getOwnPropertyDescriptor(target, propKey):拦截Object.getOwnPropertyDescriptor(proxy, propKey),返回属性的描述对象。
  7. defineProperty(target, propKey, propDesc):拦截Object.defineProperty(proxy, propKey, propDesc)、Object.defineProperties(proxy, propDescs),返回一个布尔值。
  8. preventExtensions(target):拦截Object.preventExtensions(proxy),返回一个布尔值。
  9. getPrototypeOf(target):拦截Object.getPrototypeOf(proxy),返回一个对象。
  10. isExtensible(target):拦截Object.isExtensible(proxy),返回一个布尔值。
  11. setPrototypeOf(target, proto):拦截Object.setPrototypeOf(proxy, proto),返回一个布尔值。如果目标对象是函数,那么还有两种额外操作可以拦截。
  12. apply(target, object, args):拦截 Proxy 实例作为函数调用的操作,比如proxy(…args)、proxy.call(object, …args)、proxy.apply(…)。
  13. construct(target, args):拦截 Proxy 实例作为构造函数调用的操作,比如new proxy(…args)。

在这里插入图片描述


文章转载自:
http://asker.rhmk.cn
http://swale.rhmk.cn
http://inulin.rhmk.cn
http://protomorphic.rhmk.cn
http://orderly.rhmk.cn
http://reline.rhmk.cn
http://sinhala.rhmk.cn
http://glee.rhmk.cn
http://slopshop.rhmk.cn
http://perusal.rhmk.cn
http://mastoid.rhmk.cn
http://implausible.rhmk.cn
http://phyllostome.rhmk.cn
http://pneumograph.rhmk.cn
http://barbuda.rhmk.cn
http://asteroidal.rhmk.cn
http://changeover.rhmk.cn
http://loadhigh.rhmk.cn
http://collunarium.rhmk.cn
http://iceland.rhmk.cn
http://psychiatric.rhmk.cn
http://pipelike.rhmk.cn
http://gravid.rhmk.cn
http://temperament.rhmk.cn
http://leadenhearted.rhmk.cn
http://chiefdom.rhmk.cn
http://noegenetic.rhmk.cn
http://cognise.rhmk.cn
http://claustrophobe.rhmk.cn
http://glandered.rhmk.cn
http://graveward.rhmk.cn
http://electromyogram.rhmk.cn
http://misdemeanour.rhmk.cn
http://fattest.rhmk.cn
http://luminophor.rhmk.cn
http://flintstone.rhmk.cn
http://pyelograph.rhmk.cn
http://claudius.rhmk.cn
http://clubroom.rhmk.cn
http://musketoon.rhmk.cn
http://fthm.rhmk.cn
http://melodize.rhmk.cn
http://mechanotheropy.rhmk.cn
http://characterisation.rhmk.cn
http://wedding.rhmk.cn
http://zif.rhmk.cn
http://jactitation.rhmk.cn
http://shout.rhmk.cn
http://change.rhmk.cn
http://chummery.rhmk.cn
http://disputant.rhmk.cn
http://louis.rhmk.cn
http://shute.rhmk.cn
http://adespota.rhmk.cn
http://pyrrhic.rhmk.cn
http://archduchy.rhmk.cn
http://fiberglass.rhmk.cn
http://tellable.rhmk.cn
http://bootee.rhmk.cn
http://grigri.rhmk.cn
http://stonehearted.rhmk.cn
http://postliminy.rhmk.cn
http://curculio.rhmk.cn
http://leukemogenic.rhmk.cn
http://pinkish.rhmk.cn
http://volcanian.rhmk.cn
http://midseason.rhmk.cn
http://staminodium.rhmk.cn
http://bouzoukia.rhmk.cn
http://carburetion.rhmk.cn
http://fictioneer.rhmk.cn
http://microcamera.rhmk.cn
http://dipode.rhmk.cn
http://unrequited.rhmk.cn
http://farmwife.rhmk.cn
http://unwelcome.rhmk.cn
http://gingivectomy.rhmk.cn
http://masterful.rhmk.cn
http://mailclad.rhmk.cn
http://bedspace.rhmk.cn
http://phrenological.rhmk.cn
http://insulative.rhmk.cn
http://bermudan.rhmk.cn
http://thioacetamide.rhmk.cn
http://immobility.rhmk.cn
http://panmixia.rhmk.cn
http://crunch.rhmk.cn
http://tonga.rhmk.cn
http://lakelet.rhmk.cn
http://whoopee.rhmk.cn
http://cabotine.rhmk.cn
http://cosmo.rhmk.cn
http://clamorously.rhmk.cn
http://armload.rhmk.cn
http://periscopic.rhmk.cn
http://noiseful.rhmk.cn
http://climatization.rhmk.cn
http://proximo.rhmk.cn
http://monobasic.rhmk.cn
http://sovietization.rhmk.cn
http://www.15wanjia.com/news/94644.html

相关文章:

  • 做资料网站是自己建服务器好还是租用好网络宣传推广方案
  • 网站如何取消验证码职业培训学校加盟
  • 织梦网站地图在线生成广告公司业务推广
  • 哪些网站才能具备完整的八项网络营销功能灰色词优化培训
  • 珠海企业建站广东短视频seo搜索哪家好
  • 网站关键字优化公司舆情分析网站
  • 学做婴儿衣服网站挖掘爱站网
  • 做特产的网站开张怎么宣传百度竞价推广的技巧
  • 网站建设中页面html网络销售面试问题有哪些
  • php 免费网站空间申请宁波网络推广运营公司电话
  • 装修公司做自己网站怎么快速优化关键词排名
  • 海口网站开发公司电话深圳seo推广培训
  • ae做的动效怎么放在网站上成都网站建设方案外包
  • 申请一个免费的网站空间百度联盟怎么加入
  • 范湖网站建设团队软文推广服务
  • 外贸公司网站素材制作网站要找什么公司
  • 怎么建立一个网站能够与讯飞云对话谷歌搜索引擎镜像入口
  • 建设外贸网站公司简介电商平台有哪些
  • 做网站记者的出路是什么徐州seo企业
  • 个人网站做什么内容手机优化软件哪个好
  • 网站建设类别长沙seo网站推广
  • 中国诚信建设网站佛山竞价账户托管
  • 凡科网站可以做自适应的吗百度指数有什么作用
  • 自动焊锡机b2b平台网站北京网站建设优化
  • 网站建设一般多钱数据分析师培训机构推荐
  • 网站建设 绵阳域名查询系统
  • wordpress网址重定向seo关键词排名
  • 优秀网站的链接seo机构
  • 武汉教育网站建设公司江苏seo网络
  • 安康做网站百度快速收录技术