欢迎来到"雪碧聊技术"CSDN博客!
在这里,您将踏入一个专注于Java开发技术的知识殿堂。无论您是Java编程的初学者,还是具有一定经验的开发者,相信我的博客都能为您提供宝贵的学习资源和实用技巧。作为您的技术向导,我将不断探索Java的深邃世界,分享最新的技术动态、实战经验以及项目心得。
让我们一同在Java的广阔天地中遨游,携手提升技术能力,共创美好未来!感谢您的关注与支持,期待在"雪碧聊技术"与您共同成长!
目录
①等我们学到以后,必须使用这种用函数返回data的方式。(如果不这么做,以后肯定会报错)
[②用函数返回data时,一定不要写箭头函数()=>{},因为这么写,导致this不再是vue实例,而是window ,根本原因是箭头函数中不存在this的概念,因此就会往上找this。](#②用函数返回data时,一定不要写箭头函数()=>{},因为这么写,导致this不再是vue实例,而是window ,根本原因是箭头函数中不存在this的概念,因此就会往上找this。)
①M:模型(Model),对应vue实例的data中的数据。
③VM:视图模型(ViewModel),指的是vue实例对象。
注意:由于vue实例在MVVM模型中,是VM这个角色,因此以后vue实例都会命名为VM这个名称。
[举例:在容器中,通过{{ }}可以访问vue实例的所有内容。](#举例:在容器中,通过{{ }}可以访问vue实例的所有内容。)
1、Object.defineProperty方法是用来干什么的?
①通过Object.defineProperty添加的属性,默认是不可以遍历的
②通过Object.defineProperty添加的属性,默认是不可以修改的
③通过Object.defineProperty添加的属性,默认是不可以删除的
6、Object.defineProperty中的get方法
②举例:通过读取变量number的值,作为追加属性age的值。
7、Object.defineProperty中的set方法
一、el、data的两种写法
1、el的作用
用来将容器和vue实例进行绑定。
举例:
data:image/s3,"s3://crabby-images/43b8b/43b8bf1d98cd8062ade1372605e23504ea31e80e" alt=""
2、el的替代写法
vue实例名.$mount('容器选择器')
举例:
data:image/s3,"s3://crabby-images/bd028/bd028ec20243890050544f26327798e522fc253e" alt=""
3、data的作用
声明vue实例中的数据,这样才能给html容器(在vue中叫"模板")中的数据赋值。
4、data的替代写法
举例:
data:image/s3,"s3://crabby-images/7b5c3/7b5c32b7ec30852b5556f1a1864eefa03c890498" alt=""
进一步化简:
data:image/s3,"s3://crabby-images/09d01/09d01e6f27963fefd4c2a365b4367e6bc4981abc" alt=""
注意:
①等我们学到以后,必须使用这种用函数返回data的方式。(如果不这么做,以后肯定会报错)
②用函数返回data时,一定不要写箭头函数()=>{},因为这么写,导致this不再是vue实例,而是window ,根本原因是箭头函数中不存在this的概念,因此就会往上找this。
5、总结
data:image/s3,"s3://crabby-images/de98d/de98d79b0d5fcbb7996985efd84525799141ea26" alt=""
二、理解MVVM
1、什么是MVVM?
①M:模型(Model),对应vue实例的data中的数据。
②V:视图(View),模板,即html容器。
③VM:视图模型(ViewModel),指的是vue实例对象。
data:image/s3,"s3://crabby-images/70891/70891e88707993d6c6308fef21cc763bae77dd21" alt=""
2、图示
data:image/s3,"s3://crabby-images/f1906/f19062c8713b24ec5d4132e2712f9e9f348d5ab8" alt=""
运行结果:
data:image/s3,"s3://crabby-images/5735c/5735ca88dcbbcf74372850b8223a712f586278bf" alt=""
注意:由于vue实例在MVVM模型中,是VM这个角色,因此以后vue实例都会命名为VM这个名称。
举例:
data:image/s3,"s3://crabby-images/ea61f/ea61f3cbd41b9b0c30d110ea0037db2791995a64" alt=""
3、总结
data:image/s3,"s3://crabby-images/a3113/a31136dba5ce82889f8525ecea36f44b7f4381c1" alt=""
举例:在容器中,通过{{ }}可以访问vue实例的所有内容。
data:image/s3,"s3://crabby-images/3d577/3d577191973c0da03c29e7a0886eabd09a491b41" alt=""
三、Object.defineProperty方法
1、Object.defineProperty方法是用来干什么的?
用来给对象添加一个属性。
2、举例:给对象添加一个属性
data:image/s3,"s3://crabby-images/1e008/1e0085a444a0f6ec8f0784134fa659b540a8854d" alt=""
运行结果:
data:image/s3,"s3://crabby-images/54492/54492d22641554a4e1eefd9d46b1549f8de603b4" alt=""
3、存在的问题
①通过Object.defineProperty添加的属性,默认是不可以遍历的
举例:
data:image/s3,"s3://crabby-images/2fd9e/2fd9ef8735965257674e822d2989248ab3079c74" alt=""
运行结果:
data:image/s3,"s3://crabby-images/1870f/1870f1440c660f898904ba9e6fc994cb319e376a" alt=""
②通过Object.defineProperty添加的属性,默认是不可以修改的
举例:
data:image/s3,"s3://crabby-images/da084/da08416acf8cd1d78e7bb0f8802979eb13b6858d" alt=""
③通过Object.defineProperty添加的属性,默认是不可以删除的
举例:
data:image/s3,"s3://crabby-images/d99c9/d99c9a7173f2f5884a2bb372ce33d211911750b0" alt=""
4、解决上述问题
data:image/s3,"s3://crabby-images/2aa12/2aa12732546e8c290a1a6e309aa3f84ddac53b45" alt=""
5、Object.defineProperty方法的好处
使用该方法添加的对象属性,可以对其进行很多限制,比如:对象的属性是否可以被枚举、被修改、被删除等等,在某些特定场景下,是需要这些限制的。
6、Object.defineProperty中的get方法
①作用:读取变量的值,作为属性的值。
②举例:通过读取变量number的值,作为追加属性age的值。
data:image/s3,"s3://crabby-images/0dfcb/0dfcb33e5e3429f34ae1dd5cea5e04e2c2ad6b58" alt=""
运行效果:
data:image/s3,"s3://crabby-images/10eb1/10eb1659c9d148186f908524ae6fcc4e667a2e7a" alt=""
data:image/s3,"s3://crabby-images/023cb/023cb79635ef2046b209784475cfc13780f18b0c" alt=""
7、Object.defineProperty中的set方法
①作用:用来接收属性被修改时,修改后的值。
②举例:
data:image/s3,"s3://crabby-images/ccd47/ccd47ac3c0d4b5f2aeaee0219e2f5c765529c24c" alt=""
data:image/s3,"s3://crabby-images/a487d/a487d9f59e5b97e5b48ba3790cad21a523e58c99" alt=""
③存在的问题:person中的age属性没变化
data:image/s3,"s3://crabby-images/1b45b/1b45b1de19608897a5a1a34693c9535303a45f6e" alt=""
④改进:在set方法中,刷新number变量的值
data:image/s3,"s3://crabby-images/e6c19/e6c19488d30e134190537088eb1558ba04867fa5" alt=""
运行效果:
data:image/s3,"s3://crabby-images/9d4b4/9d4b4e3eb8d41f8d601f2c9bcef4d7123831330e" alt=""
8、方法简写问题
举例:
data:image/s3,"s3://crabby-images/3efa7/3efa7214c65ca8f25d922d465a5ca71f5d5b2a19" alt=""
简写后:
data:image/s3,"s3://crabby-images/ef6fc/ef6fcdebd35795f9c45f0f5ab0ad7b50e2b14ead" alt=""
四、数据代理
1、什么是数据代理?
通过一个对象代理,对另一个对象中的属性进行操作(读/写)。
2、举例:让对象obj2,代理对象obj
data:image/s3,"s3://crabby-images/f77c7/f77c7a7c7b5ed4ccc04c510ca8ebc22ec5b0429a" alt=""
运行结果:
data:image/s3,"s3://crabby-images/59106/59106131f0b56df2c232bf1f42cde71f9d82ecb4" alt=""