美文网首页
js学习过程中的小细节记录

js学习过程中的小细节记录

作者: 暴躁的狮子头 | 来源:发表于2019-04-02 12:09 被阅读0次

连接字符串

要把多个字符串连接起来,可以用+号连接:

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为字符串提供了一些常用方法,注意,调用这些方法本身不会改变原有字符串的内容,而是返回一个新字符串

join

join()方法是一个非常实用的方法,它把当前Array的每个元素都用指定的字符串连接起来,然后返回连接后的字符串:

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

如果Array的元素不是字符串,将自动转换为字符串后再连接。

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

因为toString定义在object对象中,而所有对象最终都会在原型链上指向object,所以xiaoming也拥有toString属性。

要判断一个属性是否是xiaoming自身拥有的,而不是继承得到的,可以用hasOwnProperty()方法:

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

调用其他模块的函数

问题是其他模块怎么使用hello模块的这个greet函数呢?我们再编写一个main.js文件,调用hello模块的greet函数:

'use strict';

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

var s = 'Michael';

greet(s); // Hello, Michael!

一定要注意相对路径~

将数据存储到本地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() {
    // 获取当前时间
    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文档

调用当前时间:

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

比较时间前后:

this.ctx.app.moment().isAfter(expires_time)   //当前时间是否晚于expires_time
this.ctx.app.moment().isBefore(expires_time)     //当前时间是否早于expires_time
返回结果:true/false

测试文件:post方式

it('should POST /api/v3/lgc/jdwl/order', () => {
    return app.httpRequest()
      .post('/api/v3/lgc/jdwl/order')
      .send({
        receiveName: '测试',
        receiveAddress: '北京海淀区三环到四环之间海淀路19-1号中成大厦1109',
        receiveMobile: '17200692200',
        orderId: 'XMU201807030088',
      })
      .expect('{"status_code":200,"message":"OK","code":200,"data":{"resultCode":104,"deliveryId":"VA43230385726","resultMessage":"重复运单"}}')
      .expect(200);
  });

object[element]的使用:

const data = {
  name: 'nick',
  age: '16',
};
const arr = [ 'name' ];
arr.forEach(
  e => {
    console.log(data[e]);
  }
);

相关文章

  • js学习过程中的小细节记录

    连接字符串 要把多个字符串连接起来,可以用+号连接: 如果有很多变量需要连接,用+号就比较麻烦。ES6新增了一种模...

  • Js流水账知识点

    在学js的过程中,记录一些零碎的小知识,以便以后翻看。持续更新……学习资料:JavaScript教程 以及 《你不...

  • Javascirpt 语法(一)

    原生js学习笔记 内容中的链接是相关的学习链接 是学习过程中的记录在代码中 开发环境配置 -安装HBuilder:...

  • 转《FM,FFM,DeepFM》

    本文仅为记录学习FM、FFM、DeepFM过程中的一些理解,并不会涉及太多公式细节推导,细节方面可以参考 深入FF...

  • js小细节

    1.jquery判断对象是否为空的方法: return: true/false $.isEmptyObject(obj)

  • 一些开发中的不常见JS细节

    最近在开发中遇到一些js小细节,很容易出错,应该是以前学习js时没有系统性,完整性学习JavaScript带来的弊...

  • js运算符优先级

    最近在系统的重新学习js的知识,看到了优先级的相关资料,以前都没有注意到过的小细节,今天记录一下,如果以后有机会遇...

  • 记一次对Koa.js middleware的源码贡献

    本文主要记录笔者在使用开源Node.js web框架Koa.js过程中遇到的一个小bug,为修复此Bug查找Koa...

  • 2016年2月21日随笔

    1.瞎BB 今天本人开始做毕设设计了,那么就来记录下以前学习过程中没有注意到的细节,以及分享一点小技巧吧。 2.A...

  • 微信小程序---同步异步问题(setInterval)

    学习开发小程序过程中,发现小程序的代码执行的顺序并不是那么同步。例如app.js的生命周期顺序和index.js的...

网友评论

      本文标题:js学习过程中的小细节记录

      本文链接:https://www.haomeiwen.com/subject/weayyftx.html