欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解JavaScript中操作符和表達(dá)式

 更新時(shí)間:2018年09月12日 14:07:23   投稿:laozhang  
本篇文章給大家分享了關(guān)于JavaScript中操作符和表達(dá)式的相關(guān)知識(shí)點(diǎn)內(nèi)容,有興趣的朋友們參考下吧。

一、一元操作符

1.delete操作符

delete 操作符用于刪除對(duì)象的某個(gè)屬性;如果沒有指向這個(gè)屬性的引用,那它最終會(huì)被釋放

語(yǔ)法:delete expression

delete 操作符會(huì)從某個(gè)對(duì)象上移除指定屬性。成功刪除的時(shí)候回返回 true,否則返回 false

let Employee = {
   age: 28,
   name: 'abc',
   designation: 'developer'
 };
 console.log(delete Employee.name);  // returns true
 console.log(delete Employee.age);  // returns true
 console.log(Employee); //{designation: "developer"}

2.typeof操作符

typeof操作符返回一個(gè)字符串,表示未經(jīng)計(jì)算的操作數(shù)的類型

語(yǔ)法:typeof operand; typeof (operand);

typeof NaN === 'number';
typeof Number(1) === 'number';
typeof "" === 'string';
typeof true === 'boolean';
typeof Symbol('foo') === 'symbol';
typeof undefined === 'undefined';
typeof null === 'object'
typeof [1, 2, 4] === 'object';
typeof new Boolean(true) === 'object';
typeof new Number(1) === 'object';
typeof new String("abc") === 'object';
typeof function(){} === 'function';

3.void運(yùn)算符

void 運(yùn)算符 對(duì)給定的表達(dá)式進(jìn)行求值,然后返回 undefined

語(yǔ)法:void expression

<a href="javascript:void(0);" rel="external nofollow" >
 這個(gè)鏈接點(diǎn)擊之后不會(huì)做任何事情,如果去掉 void(),
 點(diǎn)擊之后整個(gè)頁(yè)面會(huì)被替換成一個(gè)字符 0。
</a>
<p> chrome中即使<a href="javascript:0;" rel="external nofollow" >也沒變化,firefox中會(huì)變成一個(gè)字符串0 </p>
<a href="javascript:void(document.body.style.backgroundColor='green');" rel="external nofollow" >
 點(diǎn)擊這個(gè)鏈接會(huì)讓頁(yè)面背景變成綠色。
</a>

二、關(guān)系操作符

1.in運(yùn)算符

如果指定的屬性在指定的對(duì)象或其原型鏈中,則in 運(yùn)算符返回true

語(yǔ)法:prop in object

let trees = new Array("redwood", "bay", "cedar", "oak", "maple");
console.log(0 in trees); // 返回true
console.log(3 in trees); // 返回true
console.log(6 in trees); // 返回false
console.log("bay" in trees); // 返回false (必須使用索引號(hào),而不是數(shù)組元素的值)
console.log("length" in trees); // 返回true (length是一個(gè)數(shù)組屬性)

2.instanceof運(yùn)算符

instanceof 運(yùn)算符用來(lái)測(cè)試一個(gè)對(duì)象在其原型鏈中是否存在一個(gè)構(gòu)造函數(shù)的 prototype 屬性

語(yǔ)法:object instanceof constructor

let simpleStr = "This is a simple string";
let myString = new String();
let newStr  = new String("String created with constructor");
let myDate  = new Date();
let myObj   = {};
simpleStr instanceof String; // 返回 false, 檢查原型鏈會(huì)找到 undefined
myString instanceof String; // 返回 true
newStr  instanceof String; // 返回 true
myString instanceof Object; // 返回 true
myDate instanceof Date;   // 返回 true
myObj instanceof Object;  // 返回 true, 盡管原型沒有定義

三、表達(dá)式

1.this

在函數(shù)內(nèi)部,this的值取決于函數(shù)被調(diào)用的方式。在嚴(yán)格模式下,this將保持他進(jìn)入執(zhí)行上下文時(shí)的值,所以下面的this將會(huì)默認(rèn)為undefined

function f2(){
 "use strict"; // 這里是嚴(yán)格模式
 return this;
}
f2() === undefined; // true

當(dāng)一個(gè)函數(shù)在其主體中使用 this 關(guān)鍵字時(shí),可以通過(guò)使用函數(shù)繼承自Function.prototype 的 call 或 apply 方法將 this 值綁定到調(diào)用中的特定對(duì)象

function add(c, d) {
 return this.a + this.b + c + d;
}
let o = {a: 1, b: 3};
// 第一個(gè)參數(shù)是作為‘this'使用的對(duì)象
// 后續(xù)參數(shù)作為參數(shù)傳遞給函數(shù)調(diào)用
add.call(o, 5, 7); // 1 + 3 + 5 + 7 = 16

調(diào)用f.bind(someObject)會(huì)創(chuàng)建一個(gè)與f具有相同函數(shù)體和作用域的函數(shù),但是在這個(gè)新函數(shù)中,this將永久地被綁定到了bind的第一個(gè)參數(shù),無(wú)論這個(gè)函數(shù)是如何被調(diào)用的

function f(){
 return this.a;
}
let g = f.bind({a:"azerty"});
console.log(g()); // azerty
let h = g.bind({a:'yoo'}); // bind只生效一次!
console.log(h()); // azerty

在箭頭函數(shù)中,this與封閉詞法上下文的this保持一致。在全局代碼中,它將被設(shè)置為全局對(duì)象

let globalObject = this;
let foo = (() => this);
console.log(foo() === globalObject); // true

2.super

語(yǔ)法:

super([arguments]); // 調(diào)用 父對(duì)象/父類 的構(gòu)造函數(shù)

super.functionOnParent([arguments]); // 調(diào)用 父對(duì)象/父類 上的方法

在構(gòu)造函數(shù)中使用時(shí),super關(guān)鍵字將單獨(dú)出現(xiàn),并且必須在使用this關(guān)鍵字之前使用。super關(guān)鍵字也可以用來(lái)調(diào)用父對(duì)象上的函數(shù)

class Human {
 constructor() {}
 static ping() {
  return 'ping';
 }
}
 
class Computer extends Human {
 constructor() {}
 static pingpong() {
  return super.ping() + ' pong';
 }
}
Computer.pingpong(); // 'ping pong'

3.new

new 運(yùn)算符創(chuàng)建一個(gè)用戶定義的對(duì)象類型的實(shí)例或具有構(gòu)造函數(shù)的內(nèi)置對(duì)象的實(shí)例

function Car() {}
car1 = new Car()
console.log(car1.color)      // undefined
Car.prototype.color = null
console.log(car1.color)      // null
car1.color = "black"
console.log(car1.color)      // black

4.展開語(yǔ)法

可以在函數(shù)調(diào)用/數(shù)組構(gòu)造時(shí), 將數(shù)組表達(dá)式或者string在語(yǔ)法層面展開;還可以在構(gòu)造字面量對(duì)象時(shí), 將對(duì)象表達(dá)式按key-value的方式展開

在函數(shù)調(diào)用時(shí)使用展開語(yǔ)法

function myFunction(x, y, z) { }
let args = [0, 1, 2];
myFunction.apply(null, args);
 
//展開語(yǔ)法
function myFunction(x, y, z) { }
let args = [0, 1, 2];
myFunction(...args);

構(gòu)造字面量數(shù)組時(shí)使用展開語(yǔ)法

let parts = ['shoulders','knees']; 
let lyrics = ['head',... parts,'and','toes']; 
// ["head", "shoulders", "knees", "and", "toes"]

數(shù)組拷貝

let arr = [1, 2, 3];
let arr2 = [...arr]; // like arr.slice()
arr2.push(4); 
 
// arr2 此時(shí)變成 [1, 2, 3, 4]
// arr 不受影響

連接多個(gè)數(shù)組

let arr1 = [0, 1, 2];
let arr2 = [3, 4, 5];
// 將 arr2 中所有元素附加到 arr1 后面并返回
let arr3 = arr1.concat(arr2);
 
//使用展開語(yǔ)法
let arr1 = [0, 1, 2];
let arr2 = [3, 4, 5];
let arr3 = [...arr1, ...arr2];

5.類表達(dá)式

類表達(dá)式是用來(lái)定義類的一種語(yǔ)法

let Foo = class {
 constructor() {}
 bar() {
  return "Hello World!";
 }
};
let instance = new Foo();
instance.bar(); 
// "Hello World!"

6.函數(shù)表達(dá)式

function 關(guān)鍵字可以用來(lái)在一個(gè)表達(dá)式中定義一個(gè)函數(shù),你也可以使用 Function 構(gòu)造函數(shù)和一個(gè)函數(shù)聲明來(lái)定義函數(shù)
函數(shù)聲明提升和函數(shù)表達(dá)式提升:JavaScript中的函數(shù)表達(dá)式?jīng)]有提升,不像函數(shù)聲明,你在定義函數(shù)表達(dá)式之前不能使用函數(shù)表達(dá)式

/* 函數(shù)聲明 */
 
foo(); // "bar"
function foo() {
 console.log("bar");
}
 
 
/* 函數(shù)表達(dá)式 */
 
baz(); // TypeError: baz is not a function
let baz = function() {
 console.log("bar2");
};

7.function*表達(dá)式

function關(guān)鍵字可以在表達(dá)式內(nèi)部定義一個(gè)生成器函數(shù),function 這種聲明方式(function關(guān)鍵字后跟一個(gè)星號(hào))會(huì)定義一個(gè)生成器函數(shù)(generator function),它返回一個(gè) Generator 對(duì)象

語(yǔ)法:function* name([param[, param[, ... param]]]) { statements }

function* idMaker(){
 let index = 0;
 while(index<3)
  yield index++;
}
 
let gen = idMaker();
console.log(gen.next().value); // 0
console.log(gen.next().value); // 1
console.log(gen.next().value); // 2
console.log(gen.next().value); // undefined

接收參數(shù)

function* idMaker(){
  let index = arguments[0] || 0;
  while(true)
    yield index++;
}
 
let gen = idMaker(5);
console.log(gen.next().value); // 5
console.log(gen.next().value); // 6

傳遞參數(shù)

function *createIterator() {
  let first = yield 1;
  let second = yield first + 2; // 4 + 2 
                 // first =4 是next(4)將參數(shù)賦給上一條的
  yield second + 3;       // 5 + 3
}
 
let iterator = createIterator();
 
console.log(iterator.next());  // "{ value: 1, done: false }"
console.log(iterator.next(4));  // "{ value: 6, done: false }"
console.log(iterator.next(5));  // "{ value: 8, done: false }"
console.log(iterator.next());  // "{ value: undefined, done: true }"

表達(dá)式

let x = function*(y) {
  yield y * y;
};

相關(guān)文章

  • javascript String 對(duì)象

    javascript String 對(duì)象

    javascript數(shù)據(jù)庫(kù)操作方法包括字符串大小寫,字符串搜索,提取字符串等
    2008-04-04
  • 基于Asp.net與Javascript控制的日期控件

    基于Asp.net與Javascript控制的日期控件

    使用Asp.net+Javascript控制的日期控件,需要的朋友可以參考下。
    2010-05-05
  • js實(shí)現(xiàn)照片墻功能實(shí)例

    js實(shí)現(xiàn)照片墻功能實(shí)例

    這篇文章主要介紹了js實(shí)現(xiàn)照片墻功能的方法,以一個(gè)完整實(shí)例形式分析了js實(shí)現(xiàn)照片墻的css與js的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • js+audio實(shí)現(xiàn)音樂播放器

    js+audio實(shí)現(xiàn)音樂播放器

    這篇文章主要為大家詳細(xì)介紹了js+audio實(shí)現(xiàn)音樂播放器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Ajax跨域?qū)崿F(xiàn)代碼(后臺(tái)jsp)

    Ajax跨域?qū)崿F(xiàn)代碼(后臺(tái)jsp)

    這篇文章主要介紹了Ajax跨域?qū)崿F(xiàn)代碼(后臺(tái)jsp),需要的朋友可以參考下
    2017-01-01
  • JavaScript中變量提升和函數(shù)提升實(shí)例詳解

    JavaScript中變量提升和函數(shù)提升實(shí)例詳解

    這篇文章主要給大家介紹了關(guān)于JavaScript中變量提升和函數(shù)提升的相關(guān)資料,以及JS變量提升和函數(shù)提升的順序,文中給出了詳細(xì)的介紹,需要的朋友可以參考下
    2021-07-07
  • 分享10個(gè)優(yōu)化代碼的CSS和JavaScript工具

    分享10個(gè)優(yōu)化代碼的CSS和JavaScript工具

    如果你想在保持文件的時(shí)候或執(zhí) 行的階段lint代碼,那么linting工具也可以如你所愿。這取決于個(gè)人的選擇。如果你正在找尋用于CSS和JavaScript最好的 linting工具,那么請(qǐng)繼續(xù)閱讀
    2016-05-05
  • js+canvas實(shí)現(xiàn)驗(yàn)證碼功能

    js+canvas實(shí)現(xiàn)驗(yàn)證碼功能

    這篇文章主要為大家詳細(xì)介紹了js+canvas實(shí)現(xiàn)驗(yàn)證碼功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • Cocos2d實(shí)現(xiàn)刮刮卡效果

    Cocos2d實(shí)現(xiàn)刮刮卡效果

    這篇文章主要為大家詳細(xì)介紹了Cocos2d實(shí)現(xiàn)刮刮卡效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • JavaScript async/await原理及實(shí)例解析

    JavaScript async/await原理及實(shí)例解析

    這篇文章主要介紹了JavaScript async/await原理及實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-12-12

最新評(píng)論