js學(xué)習(xí)過程中的小細(xì)節(jié)記錄

連接字符串

要把多個字符串連接起來,可以用+號連接:

var name = '小明';
var age = 20;
var message = '你好, ' + name + ', 你今年' + age + '歲了!';
alert(message);

如果有很多變量需要連接,用+號就比較麻煩。ES6新增了一種模板字符串,表示方法和上面的多行字符串一樣,但是它會自動替換字符串中的變量:

var name = '小明';
var age = 20;
var message = `你好, ${name}, 你今年${age}歲了!`;
alert(message);

對字符串索引賦值,沒有任何效果

需要特別注意的是,字符串是不可變的,如果對字符串的某個索引賦值,不會有任何錯誤,但是,也沒有任何效果:

var s = 'Test';
s[0] = 'X';
alert(s); // s仍然為'Test'

JavaScript為字符串提供了一些常用方法,注意,調(diào)用這些方法本身不會改變原有字符串的內(nèi)容,而是返回一個新字符串

join

join()方法是一個非常實(shí)用的方法,它把當(dāng)前Array的每個元素都用指定的字符串連接起來,然后返回連接后的字符串:

var arr = ['A', 'B', 'C', 1, 2, 3];
arr.join('-'); // 'A-B-C-1-2-3'

如果Array的元素不是字符串,將自動轉(zhuǎn)換為字符串后再連接。

in

如果我們要檢測xiaoming是否擁有某一屬性,可以用in操作符:

var xiaoming = {
    name: '小明',
    birth: 1990,
    school: 'No.1 Middle School',
    height: 1.70,
    weight: 65,
    score: null
};
'name' in xiaoming; // true
'grade' in xiaoming; // false

不過要小心,如果in判斷一個屬性存在,這個屬性不一定是xiaoming的,它可能是xiaoming繼承得到的:

'toString' in xiaoming; // true

因?yàn)閠oString定義在object對象中,而所有對象最終都會在原型鏈上指向object,所以xiaoming也擁有toString屬性。

要判斷一個屬性是否是xiaoming自身擁有的,而不是繼承得到的,可以用hasOwnProperty()方法:

var xiaoming = {
    name: '小明'
};
xiaoming.hasOwnProperty('name'); // true
xiaoming.hasOwnProperty('toString'); // false

調(diào)用其他模塊的函數(shù)

問題是其他模塊怎么使用hello模塊的這個greet函數(shù)呢?我們再編寫一個main.js文件,調(diào)用hello模塊的greet函數(shù):

'use strict';

// 引入hello模塊:
var greet = require('./hello');

var s = 'Michael';

greet(s); // Hello, Michael!

一定要注意相對路徑~

將數(shù)據(jù)存儲到本地json文件中

step1:在service文件夾下建立一個json文件:mp_accesstoken.json

{"expires_time":1530527605329,"access_token":"11_f4SPoElC8pvBQrEB4DoZGBAv55fSedgL-NfbZKfi3Lh-QuDuRMYJkIYi82bdMl6OFEJvDM2uMLdCM8jpehT2suDMe-je28HkoBtvhukQdg-2lXpfq1lc3meg-HGjZdhHvJco9T9n5wY_TicnULQaAEAGXC"}

在service文件中require,然后引用即可

//app/service/mp_trial.js
const accessTokenJson = require('./mp_accesstoken');// 引入本地存儲的 access_token
const fs = require('fs');// 引入fs文件管理

class MpTrialService extends Service {
   async getAccessToken() {
    // 獲取當(dāng)前時間
    const currentTime = new Date().getTime();
    console.log(currentTime);
    // 判斷 本地存儲的 access_token 是否有效
    if (accessTokenJson.access_token === '' || accessTokenJson.expires_time < currentTime) {
      const result = await this.ctx.curl('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=wx6f6a638faa3b587c&secret=e76d8fa8e047b9fe564b785a75a05048', { dataType: 'json' });
      const data = result.data;
      console.log(data);
      if (data.access_token) {
        accessTokenJson.access_token = data.access_token;
        console.log(accessTokenJson.access_token);
        accessTokenJson.expires_time = new Date().getTime() + (parseInt(data.expires_in) - 200) * 1000;
        fs.writeFile('./app/service/mp_accesstoken.json', JSON.stringify(accessTokenJson));
        console.log(accessTokenJson.access_token);
        return accessTokenJson.access_token;
      }
      return result;

    }
    // 將本地存儲的 access_token 返回
    return accessTokenJson.access_token;
  }

}

moment

moment文檔

調(diào)用當(dāng)前時間:

 const currentTime = this.ctx.app.moment();

比較時間前后:

this.ctx.app.moment().isAfter(expires_time)   //當(dāng)前時間是否晚于expires_time
this.ctx.app.moment().isBefore(expires_time)     //當(dāng)前時間是否早于expires_time
返回結(jié)果:true/false

測試文件:post方式

it('should POST /api/v3/lgc/jdwl/order', () => {
    return app.httpRequest()
      .post('/api/v3/lgc/jdwl/order')
      .send({
        receiveName: '測試',
        receiveAddress: '北京海淀區(qū)三環(huán)到四環(huán)之間海淀路19-1號中成大廈1109',
        receiveMobile: '17200692200',
        orderId: 'XMU201807030088',
      })
      .expect('{"status_code":200,"message":"OK","code":200,"data":{"resultCode":104,"deliveryId":"VA43230385726","resultMessage":"重復(fù)運(yùn)單"}}')
      .expect(200);
  });

object[element]的使用:

const data = {
  name: 'nick',
  age: '16',
};
const arr = [ 'name' ];
arr.forEach(
  e => {
    console.log(data[e]);
  }
);
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容