js 中实现getter和setter函数方法,及运算符的特殊用法

更新日期: 2018-12-27阅读量: 2199标签: 函数

1.getter与setter

JavaScript的大部分东西是简化了的。这里我们假设有一个student对象,并且我们用student.age来访问它的age属性,如果此时定义了age属性,我们就会得到它的值,如果没有,我们就会得到undefined。

但是我们也可以编写自定义的getter和setter函数来获取我们的想要的东西,而不是直接返回对象的值,设置值的时候也是一样。这样我们就可以实现更多复杂的获取和设置字段的功能,如虚拟字段,字段验证,副作用等,ES6中添加了更加方便的语法形式。

  • getter简单说来就是一种获得属性值的方法,setter简单说来就是一种设置属性值的方法
  • getter负责查询值,它不带任何参数,setter则负责设置键值,值是以参数的形式在内部传递。

//isNaN() 函数用来确定一个值是否为NaN ,即判断该值是否为一个非数字。

const student = {
    firstName: 'job',
    lastName: 'jark',

    get fullName() {
        return this.firstName + ' ' + this.lastName;
    },

    set age(value) {
        if (isNaN(value)) throw Error("It has been a bumber");
        this_age = Number(value)
    },
    get age() {
        return this_age
    }
};
console.log(student.firstName);
student.firstName = 'jerry';
console.log(student.fullName);
student.age = '21';
console.log(student.age);
student.age = 'error';

2.运算符

 1.逗号运算符

通常逗号运算符用于在一行编写多个语句,或者在for循环中使用,比如

var a,b,n = 6;
for(a = 0,b = 0;a <= n&&b<=n;a++,b++) {
}
function  calculate() {
    return a++,console.log(a),a;
}

我们还可以用它在一行中编写有逗号分隔的多个表达式,,并返回最后一个表达式的结果。

//通过var定义的变量,作用域是整个封闭函数,是全域的 。通过let定义的变量,作用域是在块级或是子块中。

let result = number1,number2,...,numberN;


2.!!运算符

他的效果与使用两次的js否定运算符的作用是一致的。!!是将任何表达式转化为布尔类型的表达式的相对较优的运算符。

同样的,如果表达式的返回值为真值,则返回true,否则则返回false。

!!null         //returns false
!!undefined   //returns false
!!false        //returns false
!!true         //returns true 
!!""           //returns false
!!"somestring" //returns true
!!0        //returns false
!!1        //returns true
!![]        //returns true
!!{}        //returns true

3.+运算符

+运算符能够快速的将字符串转化为数字,只需要在字符串前面加上+号即可,+运算符还适用于负数,八进制,十六进制和指数,可以将date或者Moment.js对象转化为时间戳。

//时间戳(timestamp),一个能表示一份数据在某个特定时间之前已经存在的、 完整的、 可验证的数据,通常是一个字符序列,唯一地标识某一刻的时间。

+ '3.11'     //returns 3.11
+ '-4'        //returns -4
+ '0xFF'      //returns 255
+ true        //returns 1
+ '123e-5'   //returns 0.00123
+ false      //returns 0
+ null        //returns 0
+ 'Infinity' //returns Infinity
+'1,234'     //returns Nan
+dateObject   //returns 1542975502981
+momentObject //returns 1542975502981


4.~运算符

位运算符一般使用的很少,当他与数字一起使用的时候,比如~N => -(N+1),这个式子仅当 N == -1 的时候结果为0。

我们可以在indexof(..)函数前面加一个~来进行布尔检查,检查一个项是否存在于Array或者string中。

let userName = 'break jerry'

if(~userName.indexOf("break")) {
    console.log('access denied');
}else {
    console.log('access granted');
}

来自:https://www.cnblogs.com/cyk2018/archive/2018/12/26/10181527.html


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: https://www.fly63.com/article/detial/1707

引用类型作为函数参数何解

在向函数传递引用类型的参数时,相当于把引用类型的地址复制给函数内的一个局部变量,所以局部变量和传入的参数会指向内存中的同一个对象。 局部变量的变化也会映射到传入参数

Js函数式编程,给你的代码增加一点点函数式编程的特性

给你的代码增加一点点函数式编程的特性,最近我对函数式编程非常感兴趣。这个概念让我着迷:应用数学来增强抽象性和强制纯粹性,以避免副作用,并实现代码的良好可复用性。同时,函数式编程非常复杂。

浅谈async函数await用法

async和await相信大家应该不陌生,让异步处理变得更友好。其实这玩意儿就是个Generator的语法糖,想深入学习得去看看Generator,不然你可能只停留在会用的阶段。用法很简单,看代码吧。

JS 高阶函数

什么是函数?在大多数编程语言中,函数是一段独立的代码块,用来抽象处理某些通用功能的方法;主要操作是给函数传入特定对象(参数),并在方法调用结束后获得一个新的对象

工作中常用的JavaScript函数片段

返回已 size 为长度的数组分割的原数组;检查数组中某元素出现的次数;扁平化数组默认 depth 全部展开;对比两个数组并且返回其中不同的元素

js构造函数的方法

类方法是不需要进行实例化就可以使用的方法;反而实例化之后,类方法在实例中不可用。对象方法和原型方法,只有实例化之后才可以使用。

Js函数curry化

最近的某次面试被问到了两次相关的问题,但是自己居然都没答好,尤其第二次,先来看看面试官给的题目是什么样子的:这一问给我问懵逼了,add(1)(2)(3)() === add(0)(2)(4)();这样的咱会实现啊,你再多加几个参数咱也能实现啊

JS箭头函数用处/示例

在现代JS中最让人期待的特性就是关于箭头函数,用=>来标识。箭头函数有两个主要的优点:更简短的函数;更直观的作用域和this的绑定(不绑定this)

JS高阶函数reduce()的常用场景

reduce()语法:必需。初始值, 或者计算结束后的返回值。 数组求和;数组最大值;数组去重;计算数组中每个元素的出现的次数

js函数

在JavaScript中,函数其实就是对象。使函数不同于其他对象的决定性特点是函数存在一个被称为[[Call]]的内部属性。内部属性无法通过代码访问而是定义了代码执行时的行为。ECMAScript为JavaScript的对象定义了多种内部属性

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!