高清国产美女一级毛片_91短视频版在线观看www免费_久久久久久久综合_国产精品爱久久久久久久电影

福州網站建設>網站新聞>福州微信小程序

在小程序中使用ES6的新特性

發布日期:2019-10-30瀏覽次數:2572 來源:福州網站建設

https://blog.csdn.net/qq_37954086/article/details/86216642


在小程序中使用ES6的新特性
ECMAScript 6(簡稱ES6)是于2015年6月正式發布的JavaScript語言的標準,正式名為ECMAScript 2015(ES2015)。


小程序在很久之前就支持了ES6了,因此在小程序的開發中,我們可以適當的使用ES6中的一些新特性,來簡化代碼,高效開發。


在使用微信開發者工具調試之前,記得先勾選上es6轉es5選項,這樣工具才會將es6語法進行轉換。


1、模板對象
模板字符串(template string)是增強版的字符串,用反引號(`)標識。它可以當作普通字符串使用,也可以用來定義多行字符串,或者在字符串中嵌入變量,這樣就避免了使用大量的(+)來拼接字符串。例如下面的代碼:


var wechat = '1349571206zmy';
var qq = '1349571206',
// es5
console.log('my wechat is ' + wechat + ' and my qq is ' + qq);
// es6
console.lg(`my wechat is ${wechat} and my qq is ${qq}`);
1
2
3
4
5
6
2、默認參數
在es6中,函數可以有默認的參數,這樣就避免了認為的對參數進行判空或者其他處理。例如下面代碼,封裝了微信小程序原生的toast,默認傳入title參數即可。


/**
  * 顯示toast
  * @param {string} title toast標題
  * @param {string} type toast類型
  * @param {number} duration toast時長
  * @param {boolean} mask 是否顯示遮罩
  */
showToast(title, type='none', duration=1000, mask=false) {
  wx.showToast({
    title: title,
    icon: type,
    duration: duration,
    mask: mask
  });
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
3、類
ES6 提供了更接近傳統語言的寫法,引入了 Class(類)這個概念,作為對象的模板。通過class關鍵字,可以定義類。例如定義一個基礎類,來封裝微信小程序常用的方法,讓代碼有更高的復用性,也使代碼更加簡潔。與傳統語言相似,支持繼承。


// base.js
class Api {
  // 顯示toast
  showToast(title, type='none', duration=1000, mask=false) 
    wx.showToast({
      title: title,
      icon: type,
      duration: duration,
      mask: mask
    });
  }
  // ...
  // 導出
  export {
    Api
  };
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
定義好類后,可以在其他的js中進行調用。


// index.js
// 引用
import {Base} from 'base';
const base = new Base();
// ...
// 在函數中調用
onLoad() {
  base.showToast('toast');
}
1
2
3
4
5
6
7
8
9
4、解構賦值
結解構就是按照一定模式,從數組和對象中提取變量進行賦值,通過解構我們可以讓賦值更優雅便捷。例如下面的代碼:


// options={wechat:134957126zmy, email:phillzou@gmail.com}
onLoad(options) {
  // es5獲取值
  let wechat = options.wechat;
  let email = options.email;
  // es6獲取值
  let {wechat, email} = options;
}
1
2
3
4
5
6
7
8
5、箭頭函數
ES6 允許使用“箭頭”(=>)定義函數。


// es6
var sum = (num1, num2) => num1 + num2;
// es5
var sum = function(num1, num2) {
  return num1 + num2;
};
1
2
3
4
5
6
6、使用promise簡化回調
小程序中的api幾乎都是回調函數的方式,因此經常會照?;卣{里面嵌套回調的情況,這使得代碼難以理解,因此可以通過promise簡化回調。舉個簡單的例子,小程序中的圖片上傳。使用小程序進行圖片上傳的傳統方式一般分為這幾個步驟:


拍照或者選擇相冊中的圖片
請求后臺上傳接口
提示上傳成功
這樣的一個步驟下來,看看代碼會變成什么樣子。


// 選擇圖片
wx.chooseImage({
  success: (res)=>{
    // 上傳圖片  
    wx.uploadFile({
      url: 'serverUrl',
      filePath: res.tempPath[0],
      success: (res)=>{
        // 提示上傳成功
        wx.showToast({
          title: '上傳成功',
          success: (result)=>{
            // ...
          }
        });
      },
    });
  },
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
可以看到,上面的代碼由一個個回調函數嵌套,這使得代碼非常難以閱讀,下面來看看如何使用es6中的promise進行簡化。


// 選擇圖片
chooseImage() {
  return new Promise((resolve, reject) => {
    wx.chooseImage({
      success: (res)=>{
        resolve(res);
      },
    });
  });
}


// 上傳圖片
uploadFile(url, path) {
  return new Promise((resolve, reject) => {
    wx.uploadFile({
      url: url,
      filePath: path,
      success: (res)=>{
        resolve(res);
      },
    });
  });
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
上面的代碼將微信小程序api進行封裝,并以Promise對象的形式進行返回。當我們真正進行圖片上傳時,可以這樣操作。


this.chooseImage()
  .then(res => {
    return this.uploadFile(res.tempPath[0], 'serverUrl');
  })
  .then(res => {
    return this.showToast('上傳成功!');
  })
1
2
3
4
5
6
7
上面的代碼就非常的清晰,以鏈式調用的方式,能夠使人清楚的知道代碼的每一步的作用。當然,這里只是介紹了promise在小程序中的一種應用,具體在ES6中的用法還請移步ES6文檔。
————————————————
版權聲明:本文為CSDN博主「MayanDev」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/qq_37954086/article/details/86216642

以上是由福州網站建設的小編為你分享了"在小程序中使用ES6的新特性"文章,如果你在這方面有什么問題,隨時聯系我們

福州微信小程序有關的文章
如果您有什么問題,歡迎咨詢我們客服! 點擊QQ咨詢
高清国产美女一级毛片_91短视频版在线观看www免费_久久久久久久综合_国产精品爱久久久久久久电影

        欧美中文高清| 国产v日韩v欧美v| 综合国产视频| 神马日本精品| 97精品97| 成人免费一区| 精品久久视频| 国产亚洲一区二区三区啪| 欧美一区二区三区高清视频| 国产极品一区| 麻豆国产精品| 国产精品一级在线观看| 四虎精品永久免费| 亚洲我射av| 久久国产小视频| 亚洲精品88| 麻豆视频在线观看免费网站黄| 91欧美日韩在线| 91av一区| 精品国产午夜| se01亚洲视频 | 精品九九久久| 黄色网一区二区| 久久久久久婷| 久久视频一区| 99在线|亚洲一区二区| 午夜一区在线| 视频一区二区三区在线| 日韩高清中文字幕一区二区| 电影亚洲精品噜噜在线观看| 日韩精品欧美| 欧美天堂亚洲电影院在线观看| 亚洲韩日在线| 9色国产精品| 日韩精品免费视频人成| 国产视频一区二| 福利一区二区三区视频在线观看| 精品91福利视频| 欧美日韩在线播放视频| 蜜臀久久久久久久| 欧美日韩xxxx| 日韩中文欧美| 亚洲最新av| 精品久久久网| 在线国产一区二区| 日韩手机在线| 日韩国产欧美一区二区| 婷婷精品进入| 日韩国产在线不卡视频| 98精品视频| 亚洲开心激情| 一本大道色婷婷在线| 亚洲精华国产欧美| 国产精品欧美三级在线观看| 国产中文在线播放| 丝袜美腿亚洲色图| 精品三级国产| 四虎精品一区二区免费| 日韩欧美一区免费| 欧美一级网站| 亚洲欧洲午夜| 日韩一区二区三区免费播放| 日韩免费精品| 午夜av一区| 蜜臀国产一区| 18国产精品| 西西人体一区二区| 日韩电影免费在线观看| 国产精品亚洲综合在线观看| 欧美日韩在线二区| 美女免费视频一区| 天堂av一区| 国产亚洲高清视频| 精品久久美女| 日韩精品乱码av一区二区| 久久久精品五月天| 国内精品美女在线观看| 蜜桃一区二区三区在线观看| 久久久国产亚洲精品| 国产精品115| 日韩欧美中文字幕电影 | 久久中文字幕av一区二区不卡| 91成人在线精品视频| 免费日韩av片| 欧美日韩国产精品一区二区亚洲| 日韩在线观看一区| 久久精品欧洲| 国产高清视频一区二区| 日本精品久久| 日本中文字幕不卡| 免费美女久久99| 在线亚洲免费| 在线一区免费观看| 丝袜亚洲另类欧美| 亚洲欧美日韩国产一区| 好吊一区二区三区| av不卡免费看| 宅男噜噜噜66国产日韩在线观看| 香蕉成人av| 三级在线看中文字幕完整版| 91日韩在线| 日韩一区二区三区免费播放| 91视频久久| 一区二区三区视频免费观看| 久久中文字幕av一区二区不卡| 日韩在线中文| 在线一区电影| 日韩中文av| 久久91视频| 国产伊人精品| 日本亚洲三级在线| 视频一区中文字幕精品| 欧美亚洲国产日韩| 另类综合日韩欧美亚洲| 日韩理论视频| 日韩中文字幕亚洲一区二区va在线 | 亚洲深深色噜噜狠狠爱网站 | 国产精品白丝久久av网站| 久久一区视频| 亚洲福利精品| 亚洲最新av| 精品网站999| 国产综合婷婷| 少妇精品在线| 国产精品a久久久久| 中文在线中文资源| 亚洲特级毛片| 日本一区二区中文字幕| 免费在线播放第一区高清av| 深夜视频一区二区| 日本精品一区二区三区在线观看视频| 国产精品一页| 亚洲v在线看| 日本一区二区三区视频在线看| 精品视频网站| 国产一区白浆| 日韩成人免费| 亚洲a级精品| 另类中文字幕国产精品| 伊人久久大香伊蕉在人线观看热v| 欧美a在线观看| 久久亚洲国产精品一区二区| 国产精品18| 免费视频最近日韩| 日韩网站中文字幕| 国产精品美女在线观看直播| 亚洲一级特黄| 久久精品福利| 日本色综合中文字幕| 婷婷色综合网| 日韩中文在线电影| 免费在线亚洲| 日韩在线麻豆| 妖精视频成人观看www| 精品国产99| 欧美日韩一区二区高清| 视频一区国产视频| 在线视频观看日韩| 电影亚洲精品噜噜在线观看| 国产极品一区| 97精品久久| 日本亚洲不卡| 蜜桃久久精品一区二区| 欧美手机在线| 欧美少妇精品| 精品久久久亚洲| 精品中文在线| 麻豆精品久久久| 国产精品观看| 国产亚洲欧美日韩在线观看一区二区 | 亚洲一区不卡| 欧美手机在线| 免费精品国产| 999视频精品| 日韩中文字幕高清在线观看| 美女精品久久| 国产精品麻豆久久| 国产亚洲一区二区手机在线观看 | 欧美资源在线| 免费日韩视频| 视频一区在线视频| 老司机精品久久| 美女尤物久久精品| 亚洲区欧美区| 日韩精品三级| 欧美a在线观看| 麻豆成全视频免费观看在线看| 偷拍精品精品一区二区三区| 欧美一区二区三区激情视频| 欧美日韩国产亚洲一区| 亚洲黄色在线| 91亚洲精品视频在线观看| 国产日韩欧美一区二区三区在线观看 | 日韩中文欧美在线| 欧美日韩一区二区三区不卡视频| 国产精品日本一区二区三区在线| 欧美激情 亚洲a∨综合| 91亚洲国产| 亚洲欧美日韩国产| 国产欧美在线观看免费|