企业管理系统定制开发【JavaScript高级进阶】初识类,函数进阶,如何改变this指向

目录


前言

  • 👉 个人主页: 
  •  个人社区:

  • 💬 企业管理系统定制开发如果文章对你有帮助,欢迎关注、点赞、收藏(一键三连)企业管理系统定制开发和订阅专栏

1.

1.1class本质还是function

 

 1.2企业管理系统定制开发类的所有方法都定义在类的prototype属性上

1.3企业管理系统定制开发类创建的实例,里面也有_ proto_ 指向类的prototype原型对象

 

1.4

ES6的类它的绝大部分功能, ES5都可以做到,而class写法只是让对象原型的写法更加清晰、更像面向对象编程的语法而已, 语法糖就是一种便捷写法. 简单理解, 有两种方法可以实现同样的功能,但是一种写法更加清晰、 方便那么这个方法就是语法糖,对于es5来说es6就是语法糖

这俩看起来,那个比较简单呢?对就是第二个(别杠),这就是语法糖

2.数组方法

 2.1forEach

语法:数组.forEach(回调函数(value:数组当前项值,index:数组当前索引,array:数组本身))

  1. <script>
  2. var arr = [5, 6, 7];
  3. var sum = 0;
  4. arr.forEach(function (value, index, array) {
  5. console.log(value);
  6. sum += value;
  7. })
  8. console.log(sum);
  9. </script>

2.1filter(过滤元素)  

主要是用来筛选数组的(迭代遍历后得到的是一个数组,所以需要接受一下)

  1. // filter
  2. var arr1 = [12, 34, 5, 66, 78, 0];
  3. // 由于filter返回的是一个新数组所以需要接收一下newArray
  4. var newArray = arr1.filter(function (value, index) {
  5. // 找到小于10 的数
  6. return value < 10;
  7. })
  8. console.log(newArray);

2.3some(校验元素)  

用来查找数组中是否有满足条件的元素(返回值是一个Boolean的值,有该查找的元素就返回true,没有的话就返回false,当查找到第一个满足的元素时,则会停止查找)

  1. var arr = [2, 3, 4, 5, 6];
  2. var newArr= arr.some(function (value, index) {
  3. return value % 3 === 0;
  4. })
  5. console.log(newArr);

依次判断,先从第一个元素开始,查看是否满足条件如果不满足条件则接着查找,如果满足条件则返回true,如果没有任何一个元素满足条件则返回false

2.4map数据渲染

  1. var fileBlog= [
  2. {
  3. title: '【JavaScript——初始JS】',
  4. url: 'https://blog.csdn.net/zhaochen1127/article/details/125956545?spm=1001.2014.3001.5501',
  5. intr: '本文是一篇对js萌新极其友好的一篇文章....'
  6. }, {
  7. title: '【JavaScript——初始JS】',
  8. url: 'https://blog.csdn.net/zhaochen1127/article/details/125956545?spm=1001.2014.3001.5501',
  9. intr: '本文是一篇对js萌新极其友好的一篇文章....'
  10. }, {
  11. title: '【JavaScript——初始JS】',
  12. url: 'https://blog.csdn.net/zhaochen1127/article/details/125956545?spm=1001.2014.3001.5501',
  13. intr: '本文是一篇对js萌新极其友好的一篇文章....'
  14. }
  15. ]
  16. var fblog = fileBlog.map(function (item) {
  17. return `
  18. <li>
  19. <h5>${item.title}</h5>
  20. <p>${item.intr}</p>
  21. <a href="${item.url}" target="_blank">阅读博客</a>
  22. </li>
  23. `
  24. })
  25. var ul = document.querySelector('.blogs').querySelector('.bcon').querySelector('.blist');
  26. console.log( fblog.join(''));
  27. ul.innerHTML = fblog.join('');

3.字符串方法

trim()方法(trim不会影响字符串本身的,返回的是一个新的字符串)

trim指回去除两侧的空格而在字符春中间的空格不会被去除掉

4.对象方法

Object.keys() 用于获取对象自身所有的属性 object . keys (obj) ,效果类似for..in ,返回一个由属性名组成的数组

  1. var obj = {
  2. idcard:10086,
  3. uname:'山鱼',
  4. age:20,
  5. sex:'男'
  6. }
  7. var obj1 = Object.keys(obj);
  8. console.log(obj1);

4.1Object.defineProperty()定义新属性或修改原有的属性

Object.defineProperty()第三个参数descriptor说明:以对象形式{}书写

4.2value设置属性的值默认为undefined

  1. var obj = {
  2. idcard:10086,
  3. uname:'山鱼',
  4. age:20,
  5. sex:'男'
  6. }
  7. // 给obj添加一个birthday属性,属性值为‘11.27’
  8. Object.defineProperty(obj,'birthday',{
  9. value:'11.27'
  10. }
  11. )
  12. // 修改obj里面的age属性,修改后的属性值为25
  13. Object.defineProperty(obj,'age',{
  14. value:25
  15. }
  16. )
  17. console.log(obj);

4.3writable 值是否可以重写true | false默认为false

 (idcard的值并没有修改 ) 

4.4enumerable 目标属性是否可以被枚举true | false默认也为false

  1. Object.defineProperty(obj,'location',{
  2. value:'JingXian',
  3. writable:false,
  4. enumerable:false
  5. }
  6. )
  7. console.log(obj);

4.5configurabletrue| false 默认为false

目标属性是否可以被删除或是否可以再次修改特性

  1. Object.defineProperty(obj,'location',{
  2. value:'JingXian',
  3. writable:false,
  4. enumerable:false,
  5. configurable:false
  6. }
  7. )
  8. delete obj.location;
  9. console.log(obj);
  10. delete obj.uname;
  11. console.log(obj);

也不可以再次修改里面的特性  

写在最后 

生活便是寻求新的知识 —— Mendeleev

点赞👍:您的赞赏是我前进的动力!

收藏⭐:您的支持我是创作的源泉!

评论✍:您的建议是我改进的良药!

山鱼🦈社区:欢迎大家加   !

网站建设定制开发 软件系统开发定制 定制软件开发 软件开发定制 定制app开发 app开发定制 app开发定制公司 电商商城定制开发 定制小程序开发 定制开发小程序 客户管理系统开发定制 定制网站 定制开发 crm开发定制 开发公司 小程序开发定制 定制软件 收款定制开发 企业网站定制开发 定制化开发 android系统定制开发 定制小程序开发费用 定制设计 专注app软件定制开发 软件开发定制定制 知名网站建设定制 软件定制开发供应商 应用系统定制开发 软件系统定制开发 企业管理系统定制开发 系统定制开发