成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

想在vue、react中用es6,先知道這些必會的才行

lakeside / 1013人閱讀

摘要:比如引入全部引入部分引入全部并作為對象導(dǎo)出默認(rèn)部分導(dǎo)出,需引入析構(gòu)賦值析構(gòu)賦值讓我們從或里取部分?jǐn)?shù)據(jù)存為變量。對象數(shù)組我們也可以析構(gòu)傳入的函數(shù)參數(shù)。析構(gòu)時(shí)還可以配,讓代碼更具有語義。對象字面量改進(jìn)這是析構(gòu)的反向操作,用于重新組織一個(gè)。

變量聲明

const 和 let

不要用 var,而是用 const 和 let,分別表示常量和變量。不同于 var 的函數(shù)作用域,const 和 let 都是塊級作用域。

const DELAY = 1000;

let count = 0;
count = count + 1;
模板字符串

模板字符串提供了另一種做字符串組合的方法。

const user = "world";
console.log(`hello ${user}`);  // hello world

// 多行
const content = `
  Hello ${firstName},
  Thanks for ordering ${qty} tickets to ${event}.
`;
默認(rèn)參數(shù)
function logActivity(activity = "skiing") {
  console.log(activity);
}

logActivity();  // skiing
箭頭函數(shù)

函數(shù)的快捷寫法,不需要通過 function 關(guān)鍵字創(chuàng)建函數(shù),并且還可以省略 return 關(guān)鍵字。

同時(shí),箭頭函數(shù)還會繼承當(dāng)前上下文的 this 關(guān)鍵字。

比如:

[1, 2, 3].map(x => x + 1); // [2, 3, 4] 等同于: [1, 2, 3].map((function(x) { return x + 1; }).bind(this));
模塊的 Import 和 Export

import 用于引入模塊,export 用于導(dǎo)出模塊。

比如:

// 引入全部
import dva from "dva";

// 引入部分
import { connect } from "dva";
import { Link, Route } from "dva/router";

// 引入全部并作為 github 對象
import * as github from "./services/github";

// 導(dǎo)出默認(rèn)
export default App;
// 部分導(dǎo)出,需 import { App } from "./file"; 引入
export class App extend Component {};
析構(gòu)賦值

析構(gòu)賦值讓我們從 Object 或 Array 里取部分?jǐn)?shù)據(jù)存為變量。

// 對象
const user = { name: "guanguan", age: 2 };
const { name, age } = user;
console.log(`${name} : ${age}`);  // guanguan : 2

// 數(shù)組
const arr = [1, 2];
const [foo, bar] = arr;
console.log(foo);  // 1

我們也可以析構(gòu)傳入的函數(shù)參數(shù)。

const add = (state, { payload }) => {
  return state.concat(payload);
};
析構(gòu)時(shí)還可以配 alias,讓代碼更具有語義。

const add = (state, { payload: todo }) => {
  return state.concat(todo);
};
對象字面量改進(jìn)

這是析構(gòu)的反向操作,用于重新組織一個(gè) Object 。

const name = "duoduo";
const age = 8;

const user = { name, age };  // { name: "duoduo", age: 8 }

定義對象方法時(shí),還可以省去 function 關(guān)鍵字。

app.model({
  reducers: {
    add() {}  // 等同于 add: function() {}
  },
  effects: {
    *addRemote() {}  // 等同于 addRemote: function*() {}
  },
});
Spread Operator

Spread Operator 即 3 個(gè)點(diǎn) ...,有幾種不同的使用方法。

可用于組裝數(shù)組。

const todos = ["Learn dva"];
[...todos, "Learn antd"];  // ["Learn dva", "Learn antd"]
也可用于獲取數(shù)組的部分項(xiàng)。

const arr = ["a", "b", "c"];
const [first, ...rest] = arr;
rest;  // ["b", "c"]

// With ignore
const [first, , ...rest] = arr;
rest;  // ["c"]

還可收集函數(shù)參數(shù)為數(shù)組。

function directions(first, ...rest) {
  console.log(rest);
}
directions("a", "b", "c");  // ["b", "c"];
代替 apply。

function foo(x, y, z) {}
const args = [1,2,3];

// 下面兩句效果相同
foo.apply(null, args);
foo(...args);

對于 Object 而言,用于組合成新的 Object 。(ES2017 stage-2 proposal)

const foo = {
  a: 1,
  b: 2,
};
const bar = {
  b: 3,
  c: 2,
};
const d = 4;

const ret = { ...foo, ...bar, d };  // { a:1, b:3, c:2, d:4 }

此外,在 JSX 中 Spread Operator 還可用于擴(kuò)展 props,詳見 Spread Attributes。

Promises

Promise 用于更優(yōu)雅地處理異步請求。比如發(fā)起異步請求:

fetch("/api/todos")
  .then(res => res.json())
  .then(data => ({ data }))
  .catch(err => ({ err }));

定義 Promise 。

const delay = (timeout) => {
  return new Promise(resolve => {
    setTimeout(resolve, timeout);
  });
};

delay(1000).then(_ => {
  console.log("executed");
});

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/84558.html

相關(guān)文章

  • 解讀高級前端會的package.json字段

      今天想為大家講講前端項(xiàng)目的package.json文件中相關(guān)的字段含義及使用場景。我們先避免一些配置性的錯誤,提高項(xiàng)目的維護(hù)性?! ame  我們要知道當(dāng)項(xiàng)目是需要發(fā)版為npm包的,那么name字段是必須的。因?yàn)樗婕暗絥pm包的命名?! ∨e個(gè)例子  筆者曾發(fā)布過開源的npm包,名字是ping-url?! ?yīng)的源代碼package.json的定義如下:  {   "name&qu...

    3403771864 評論0 收藏0
  • 那些必會用到的 ES6 精粹

    摘要:返回布爾值,表示參數(shù)字符串是否在原字符串的頭部。然后,的應(yīng)當(dāng)會放到當(dāng)前的最后,但是還是在當(dāng)前中。函數(shù)內(nèi)部拋出錯誤,會導(dǎo)致返回的對象變?yōu)闋顟B(tài)。也就是說,只有函數(shù)內(nèi)部的異步操作執(zhí)行完,才會執(zhí)行方法指定的回調(diào)函數(shù)。 showImg(https://segmentfault.com/img/remote/1460000016460782); 前言 最新的 ECMAScript 都已經(jīng)到發(fā)布到 ...

    levy9527 評論0 收藏0
  • 前端每周清單第 34 期:Vue 現(xiàn)狀盤點(diǎn)與 3.0 展望,React 代碼遷移與優(yōu)化,圖片優(yōu)化詳論

    摘要:工程實(shí)踐立足實(shí)踐,提示實(shí)際水平內(nèi)聯(lián)函數(shù)與性能很多關(guān)于性能優(yōu)化的文章都會談及內(nèi)聯(lián)函數(shù),其也是常見的被詬病為拖慢性能表現(xiàn)的元兇之一不過本文卻是打破砂鍋問到底,論證了內(nèi)聯(lián)函數(shù)并不一定就會拖慢性能,過度的性能優(yōu)化反而會有損于應(yīng)用性能。 showImg(https://segmentfault.com/img/remote/1460000011481413?w=1240&h=825); 前端每周...

    CoderStudy 評論0 收藏0
  • 玩轉(zhuǎn) React(一)- 前言

    摘要:本人計(jì)劃編寫一個(gè)針對中初級前端開發(fā)者學(xué)習(xí)的系列教程玩轉(zhuǎn)。使用的原因是新的語言規(guī)范開發(fā)效率更高代碼更優(yōu)雅,尤其是基于開發(fā)的項(xiàng)目。其次也是目前特別流行的一個(gè)前端框架,截止目前,上有將近萬,國內(nèi)一二線互聯(lián)網(wǎng)公司都有深度依賴開發(fā)的項(xiàng)目。 本人計(jì)劃編寫一個(gè)針對中初級前端開發(fā)者學(xué)習(xí) React 的系列教程 - 《玩轉(zhuǎn) React》。 文章更新頻率:每周 1 ~ 2 篇。 目錄 玩轉(zhuǎn) React(...

    waltr 評論0 收藏0
  • 程序員口述:我是如何工作三年后跳槽到美團(tuán)的?

    摘要:終于,我在看到美團(tuán)的社招信息后,勇敢地邁出了第一步。當(dāng)時(shí)參加的是美團(tuán)點(diǎn)評部門的面試,部門前端技術(shù)棧是,后端用的。后來才知道美團(tuán)是一次性全部面完的。所以以后有去參加美團(tuán)面試的童鞋,最好做好面試四個(gè)小時(shí)的打算。 showImg(https://segmentfault.com/img/bV0c3T?w=672&h=361); 前言 我叫王小閏(花名),非科班出身,野生前端從業(yè)者,在小公司打...

    nevermind 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<