IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> JavaScript前端精确配置设置与监听器使用 -> 正文阅读

[JavaScript知识库]JavaScript前端精确配置设置与监听器使用

前端精确配置设置与监听器使用

前端JavaScript精确配置设置与监听器使用

全文总计10500字(含代码),文字约6500字,预计阅读时间为20分钟,实践加练习约为45分钟

JavaScript版本的划分

  • JS分为多个版本,通常生成 ESX ESXX
  • JS的第五个版本 ES5 ES2009·

新增特性严格模式

为代码提供了更加严格的审查机制吧一些容易出错的机制扼杀掉,后台增加更多的宝座体制--让程序员书写的代码更加可靠

看如下代码
在这里插入图片描述
在这里插入图片描述
在全局中使用的变量都默认的带有一个window

开启严格模式

在这里插入图片描述

没开启严格模式下的变量先声明再使用

变量先声明再使用例如我故意写错一位没开启严格模式就是
在这里插入图片描述

在这里插入图片描述
他会自动定义不需要声明

开启了严格模式后的变化

在这里插入图片描述

在这里插入图片描述

就会产生报错,不声明就无法使用

矩形构造函数

严格模式下–阻止/禁用 静默失败

静默失败ES5之前 很多失败的情况下,让程序员无法定位错误
比如:

 <script>
   var emp={ename:'doudou',age:19}
   // 冻结对象:可以防止内容被修改
   Object.freeze(emp);
   // 修改一下试试
   emp.age=30;
   // 显示结果
   console.log(emp);
 </script>

打印结果去没有改变,又没有报错所以非常让人抓狂

在这里插入图片描述

但是打开严格模式后之后

在这里插入图片描述
就可以出现报错了
在这里插入图片描述

新手的鸡肋,高手的神器-——对象属性的精确配置

先来看一个示例
如下图:
在这里插入图片描述

理论上来说有些属性只能看不能改
但是现在能随意修改

在这里插入图片描述
我们先来看一下Object
在这里插入图片描述
在这里插入图片描述
JS中万物皆对象,函数也是一种特殊的构造函数
就像

var emp =new Object()

{ }只是上面对象创建方式的一个语法糖
所以我们要配置对象的话就是要用到对象属性的defineProperty(定义)属性(prototype)
参数一对象
参数二属性名
参数三具体配置项

Object.defineProperty(对象,'属性名',{具体配置}) 

在这里插入图片描述
所以我们添加上对象后就是
在这里插入图片描述
添加之后我们发现是不能修改刚才定义的数据的
在这里插入图片描述
添加上严格模式可能更明确:如图
在这里插入图片描述
就会报错提示:这个数据是锁定的

精确配置之是否可遍历

demo秋山玩王者荣耀

秋山在玩王者荣耀的时候要求人脸识别所以完成实名认证后获得了信息所以要获取一下

    <script>
      var emp = {
        name: "qiushan",
        age: 21,
        sex: "0",
        Id_car: "430772xxxxxxxxxxxx0910",
        phone: "130xxxx5607",
      };
      for(var key in emp){
        console.log(key,emp[key]);
      }
    </script>

获取了信息之后要遍历一下我们只需要基本信息,其他的不让遍历
所以我们要禁止获取身份证和手机号,就可以这样写:

<script>
  var emp = {
    name: "qiushan",
    age: 21,
    sex: "0",
    Id_car: "430772xxxxxxxxxxxx0910",
    phone: "130xxxx5607",
  };

  Object.defineProperty(emp,'Id_car',{
    enumerable: false,
    // 是否可遍历/枚举:否
  })
  for(var key in emp){
    console.log(key,emp[key]);
  }
</script>

注意虽然遍历/枚举不可获取数据但是还是能正常读出来的

在这里插入图片描述
在这里插入图片描述
所以这就可用于从服务器拿到了数据,这些数据是要循环遍历的,然而又写选项在没有达到某些条件之前不会显示,或者后端接口少的情况下,条数据包含多条不相关的数据等用来屏蔽遍历插入等

精确配置配置多个属性

上面说了,属性对的配置,但是上面和之前说的方法只能,一下配置一条所以我们接下来聊聊一线配置多条属性
格式:

Object.defineProperties(数组/对象,{
	属性名:{配置项目}
})

举例公司的后台OA系统

某公司的后台OA系统从数据库获取的数据如下

var emp = {
  ename:"ashan",
  salary:14000,
  phone:'153xxxx0192',
  eid:21
}

要求:
phone和eid不能改
salary和eid不能遍历

接下来就需要使用:enumerable(无法枚举遍历)和writable(无法更改)

后台OA代码

所以代码为:

<script>
  var emp = {
    ename: "ashan",
    salary: 14000,
    phone: "153xxxx0192",
    eid: 21,
  };
  // 希望:phone和eid不能改
  // salary和eid不能遍历
  Object.defineProperties(emp, {
    // 属性名:{配置项目}
    phone: {
      writable: false,
    },
    eid: {
      writable: false,
      enumerable: false,
    },
    salary: {
      enumerable: false,
    },
  });
</script>

接下来我们测试一下吧
在这里插入图片描述
结果;
在这里插入图片描述
有的时候在日常开发中,大多都是多人协作,两个程序员之间可能会出现的情节如下

<script>
    // 开启严格模式
    'use strict';
    // 由于是多人协作
    // ------>下面是阿山的同事写的<--------

    // 创建用户信息
    var emp={
      ename:"shanhai",
      age:"28"
    }
    // 配置年龄不可被修改
    Object.defineProperty(emp,'age',{
      // 不可修改
      writable:false,
    })
    // ------>下面是阿山写的<--------
    Object.defineProperty(emp,'age',{
      writable:true
    });
    emp.age=67
    console.log(emp);
  </script>

在这里插入图片描述
这数据不久被重写了嘛,但是这样可能会影响到后续的开发,所以需要控制是否能重写

<script>
    // 开启严格模式
    'use strict';
    // ------>下面是阿山写的<--------
    // 创建用户信息
    var emp={
      ename:"shanhai",
      age:"28"
    }
    // 配置年龄不可被修改
    Object.defineProperty(emp,'age',{
      // 不可修改
      writable:false,
      // 控制是否能重写配置
      configurable:false,
      // 不可重写配置
    })
    // ------>下面是阿山的同事写的<--------
    Object.defineProperty(emp,'age',{
      writable:true
    });
    emp.age=67
    console.log(emp);
  </script>

现在我们就可以看到无法修改了
在这里插入图片描述

举例:qq空间的多人协作
在这里插入图片描述

精确配置默认值

简单来说就是允许插入的方式拒绝某种方式的插入

演示精确配置默认值

比如:

var emp={}

创建一个对象后插入数据的方式有很多种
如:

emp.ename='阿山'  
    //点语法
    emp['phone']='10086'
    // 方括号语法

使某些数据无法被修改

例如:让emp下面的手机号无法被修改等

Object.defineProperty(emp, 'phone', {
      writable: true,
});

不允许`某种方式插入就为writable的值就为false反之则为true

计算属性

看示例:计算矩形面积的函数

示例:计算矩形面积的函数

<script>
    // 矩形的对象
    var r1={
      length:10,
      height:5,
      area:function(){
        return this.length*this.height
      }
    }
    console.log(r1.area());
  </script>

调用结果:
在这里插入图片描述

语法糖

作者提供的一些简化语法,让程序员书写代码增加幸福感 – 像吃糖一样
语法糖的宗旨:省略复杂的固定的代码
比如:上面的代码简化

简化计算矩形面积的代码

area:function(){
  return this.length*this.height
}

可以用语法糖写为

area(){
  return this.length*this.height
}

get关键词

能让无参数传参的回调函数去括号
函数的括号作用是调用,如果有实参则可以传参,但是为了方便,作者提供了get关键字,不传参的回调函数可以在前面加上get来实现不用小括号调用函数
在这里插入图片描述

改写之后功能是正常的

在这里插入图片描述
但是要传参的回调函数添加get就没办法用了,用了的话你就是个大聪明,第一编辑器会报错其次,你怎么传参呢?
在这里插入图片描述
报错
在这里插入图片描述

get的实践

get:计算属性
之前我们说过了get使用了的话可以简化很多的操作
下面我们来对比一下

用get属性简写矩形的计算属性

<!-- 矩形计算 -->
<script>
  // 不使用语法糖
  var r2 = { width: 10, length: 20 };
  Object.defineProperty(r2,"area",{
    value(){
      return this.width*this.length
    }
  });
  console.log(r2.area());
  // 使用get
  // 计算属性:使用时不用加小括号
  Object.defineProperty(r2,"area2",{
    get (){
      return this.width*this.length
    }
  })
  console.log(r2.area2);
</script>
</body>

接下来我们在控制台里面看一下区别
我们发现get调用的属性默认显示三个点
在这里插入图片描述
悬停显示的调用属性,当点击之后直接就算出参数了而之前没使用get属性的值却显示为回调函数
在这里插入图片描述

练习:创建一个计算属性用于计算半径和周长
<script>
      // 计算半径
      // 计算周长
      var r1={
        width:100,
        height:50
      }
      Object.defineProperties(r1,{
        area:{
          get(){
            return this.width*this.height*3.14
          }
        },
        zc:{
          get(){
            return 2*this.width*2
          }
        }
      });
      console.log(r1);
    </script>

精确配置_set

首先我们来先看一个demo

演示demo:年龄是否合法

假设我们接到了一个用户修改信息的前端页面简化的js代码如下

<script>
    var emps={
      emane:"sahn",
      age:123
    }
    // 逻辑错误:年龄的值不可能为200岁
    emps.age=200
    console.log(emps);
  </script>

我们可以看到上面的示例中明显有个逻辑性的错误
所以我们现在不能随便往里面改,我们要检测一下,否则甲方可能会找麻烦

所以我们可以使用set属性
set : 设置 当调用这个参数(给与set赋值)的时候,也就是使用这个方法(回调函数…)就会调用下面的方法如下图
在这里插入图片描述
如下图简单来说相当于下面的结构
下图上面的是没使用set下面的是使用了set的
在这里插入图片描述
所以我们可以写为:

判断传入年龄是否合法的验证实现的分析

<script>
var emps = {
  emane: "sahn",
  age: 123,
};
Object.defineProperty(emps, "age", {
  //set:设置 检测赋值的操作
  set: function (value) {
    // value 就是传入的值
    if ((value) > 1 && value <= 100) {
      console.log('写入了:',value);
    } else {
      console.log("传入值错误")
    }
  },
});
emps.age = 200;
emps.age = 10;
emps.age = 70;
</script>

这时我们发现可以了但是打印的时候却变成了undefinde
在这里插入图片描述

为什么age的值为undefinde呢?

  • **由于age被修改为检查站,只能具备检测功能,不具备存储数据功能
  • 所以必须提供一个额外的属性存储数据(创建一个新的值)**
    写法:
// 由于是专门配合age使用的所以我们习惯添加下划线前缀
Object.defineProperty(emps,'_age',{
	// 用define属性添加的属性默认是不可写入的所以要改为写入
	writable:true
});

创建完毕后把数据转存作为中转过来
在这里插入图片描述
但是我要读取这个数据不能去读_age吧
在这里插入图片描述
所以我们的代码可以这样写

判断传入年龄是否合法的验证实现的完全代码

<script>
  var emps = {
    emane: "sahn",
    age: 123,
  };
  // 由于age被修改为检查站,只能具备检测功能,不具备存储数据功能
  // 所以必须提供一个额外的属性来存储数据
  // 由于是专门配合age使用的所以我们习惯添加下划线前缀
  Object.defineProperty(emps,'_age',{
    // 用define属性添加的属性默认是不可写入的所以要改为写入
    writable:true
  });
  Object.defineProperty(emps, "age", {
    //set:设置 检测赋值的操作
    get(){
      return this._age
    },
    set: function (value) {
      // value 就是传入的值
      if ((value) > 1 && value <= 100) {
        console.log('写入了:',value);
        this._age=value
      } else {
        console.log("传入值错误")
      }
    },
  });
  // 读取数据
  emps.age = 200;
  emps.age = 10;
  emps.age = 70;
  console.log(emps.age);
</script>

案例的核心

核心点在于
在这里插入图片描述
接下来可以尝试完成下面的练习题

练习1:制作验证工资的函数

练习1:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script>
      var emp = {
        ename: "ashan",
        salary: 13000,
      };
      Object.defineProperties(emp, {
        // ?a
      });
      // 要求工资合法范围为1000-30000员
      emp.salary = 40000;
      // 报错薪资不合法
      emp.salary = 15000;
      // 正常工资
      console.log(emp);
      console.log(emp.salary);
    </script>
  </body>
</html>

实现效果

在这里插入图片描述

练习2:制作验证身高的函数

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <script>
    var emp={
      ename:'qiushan',
      height:176
    }
    Object.defineProperties(emp,{
      // ?
    })
    // 身高范围100-200
    emp.height=300;
    emp.height=180
    console.log(emp);
    console.log(emp.height);
  </script>
</body>
</html>

实现效果

在这里插入图片描述

练习案例解析下载

案例答案如下(不需要付费下载):案例下载
在这里插入图片描述

保护对象的方式

之前讲解的精准属性配置:可以对 对象中的每个属性进行配置
对象的操作有四种:增删改查
所以保护对象的方式就是阻止代码的增删改,但是如果不能查了,代码也就失去意义了

阻止新增属性

// 阻止新增属性
      // preventExt 阻止
      // ensions 扩展
      // 不允许增
      Object.preventExtensions(emp);
      // 给秋山添加一个女朋友
      emp.grilFriend = "山海";

阻止对象曾删

      // 不允许增删:只能读
      // seal: 密封
      Object.seal(emp);
      // 删除
      delete emp.salary;

阻止对象增删改

      // 不允许增删改
      // freeze:冻结
      Object.freeze(emp);
      // 这样就只能读取了
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-08-06 10:34:49  更:2022-08-06 10:39:34 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 9:43:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码