功能及问题

如下代码,

使用用户最后一次配置信息的同时,当用户关闭数据记录时提示用户确定关闭。

  export default {
name: 'editPage',
data() {
return {
page: {},
fpSettings: {},
settingApiOk: false,
}
},
watch: {
fpSettings: {
handler(newVal) {
let pageSettings = this.page.settings || {}
if(this.settingApiOk && newVal.trace === false && pageSettings.trace === true) {
this.$dialog.confirm({
message: '确定关闭吗?',
cancelButtonText: '暂不',
confirmButtonText: '确定',
}).then(() => {
console.log('确定')
}).catch(() => {
console.log('暂不')
newVal.trace = true
})
}
this.page.settings = {...pageSettings, ...newVal}
},
deep: true,
},
},
mounted() {
http.get(`fppage/lastSetting`).then(({ settings: lastSettings } = {}) => {
http.get(`fppage/setting`).then((settings = {}) => {
this.fpSettings = Object.assign(this.fpSettings, lastSettings, settings.settings)
this.settingApiOk = true
})
})
}
}

现在有一个 bug , 在手机上, 如果选项为关闭, 刷新时会直接弹出提示窗口, 正确情况是只应该在用户设置的时候弹出。在电脑上把网速调为 Fast 3G 以下会重现。

经测试, 如果不使用 fppage/lastSetting 这个请求直接是正常的。

setting 是写在 lastSetting 的回调 then 中的, 应该他两不存在干扰问题呀。

但还是猜想有没有可能虽然写了 then ,他们依然可能同时发出请求, 同时接收到数据。

并且使用了一个 settingApiOk 变量来判断接口是否请求完成, 然而问题依旧。

改为同步方式

试图使用 async / await 异步转为同步的方法, 把 mounted 中的代码抽取 methods 中。

貌似与之前的代码也没什么不同。确实, 问题依旧。

逐步 debugger , 确定是一个接口一个接口的请求完, 代码一行一行的走的哇。

  async intSetting () {
const lastSettings = await this.$http.get(`fppage/lastSetting`)
const setting = await this.$http.get(`fppage/setting`)
this.fpSettings = Object.assign(this.fpSettings, lastSettings, setting.settings)
this.settingApiOk = true
},

干脆再加个 await 吧

看上面的代码都在前面加了 await 也都没有用, 那索性再在 Object.assign() 前面加一个试试吧。

尼玛居然成功了, 完全想不到是这个原因。 难道 Object.assign 是一个异步方法吗?傻傻分不清。

换个 … 试试

Object.assign()... 都是对象合并的方法。那换个 ... 试试呢?

  // this.fpSettings = await Object.assign(this.fpSettings, lastSettings, setting.settings)
this.fpSettings = await {...this.fpSettings, ...lastSettings, ...setting.settings}

很遗憾, 使用 ... 方式加 await 也不能解决问题。那么看来它和 Object.assign() 还是有区别的。那么区别是什么呢?

疑问

通过上面的情况, 有几个问题存在。

  1. Object.assign() 是一个异步操作吗?为什么加 await 就好了?
  2. Object.assign()... 有什么不同?

Object.assign 的问题的更多相关文章

  1. Object.assign方法复制或合并对象

    Object.assign() 方法可以把任意多个的源对象自身的可枚举属性拷贝给目标对象,然后返回目标对象 var obj = { a: 1 }; var copy = Object.assign({ ...

  2. Object.assign()方法

    对象的扩展 1.ES6中,对象的属性和方法可简写:对象的属性值可不写,前提是属性名已经声明: var name = "zhangsan"; "; var obj = { ...

  3. 微信不支持Object.assign

    微信不支持Object.assign,让我Vue怎么用QAQ... 解决方法: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Refe ...

  4. object.assign()方法的使用

    地址:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/assign

  5. [Javascript] Object.assign()

    Best Pratices for Object.assign: http://www.cnblogs.com/Answer1215/p/5096746.html Object.assign() ca ...

  6. [Redux] Avoiding Object Mutations with Object.assign() and ...spread

    Learn how to use Object.assign() and the spread operator proposed for ES7 to avoid mutating objects. ...

  7. [ES6] Object.assign (with defaults value object)

    function spinner(target, options = {}){ let defaults = { message: "Please wait", spinningS ...

  8. Object.assign()

    https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/assign 说明 Ob ...

  9. 学习Object.assign()

    Object.assign()用于将所有可枚举的值从一个或多个源对象复制到目标对象.它将返回目标对象. 语法 Object.assign(target, ...source); var obj = { ...

  10. es6 Object.assign

    ES6 Object.assign 一.基本用法 Object.assign方法用来将源对象(source)的所有可枚举属性,复制到目标对象(target).它至少需要两个对象作为参数,第一个参数是目 ...

随机推荐

  1. ruby 基础知识2 - 区块 block

    原文 1. block中的 yield 与遍历 5.times do |i| puts i end 或者 def my_times(n) i = 0 while n > i i += 1 yie ...

  2. STL之pair对组

    #include<iostream> #include<algorithm> #include<cstring> #include<cstdlib> u ...

  3. 微信小程序时间戳的转换及调用

    13位 的时间戳,如下图: 效果图: 1.(utils.js里面的代码): function formatTime(timestamp, format) { const formateArr = [' ...

  4. Java基础&面向对象(二)

    (七)函数 1.数的定义:具有特定功能的一段小程序,也称为方法: 2.函数的特点: 3.函数的应用:结果.是否需要未知内容参与运算: 4.函数的重载:在同一个类中,允许存在一个以上的同名函数,只要它们 ...

  5. Java 批量下载excel,并对excel赋值,压缩为zip文件(POI版)

    package com.neusoft.nda.servlet; import java.io.File;import java.io.FileInputStream;import java.io.F ...

  6. 强类型Dataset使用事务(改进原有方法)

    以下部份转自:http://blog.csdn.net/nfbing/article/details/5803980 关于强类型Dataset的用法和好处,我就不再多说,网上关于这方面的资料很多 , ...

  7. Visual Studio中配置Beyond Compare为版本比较工具

    VS自带的合并工具并不理想,个人比较习惯Beyond Compare,这里替换成Beyond Compare,因为并不想改变所有的VS项目设置,这里以单个仓库项目为例,源代码管理器使用GIT 找到.g ...

  8. centos6 安装python2.7 并做软件兼容处理 及 MySQLdb模块安装

    相关软件准备 https://www.python.org/ftp/python/2.7.15/Python-2.7.15.tgz https://pypi.org/project/setuptool ...

  9. Mac 软件

    http://xclient.info/?t=e0ec92ebc9ce8ef7b7a48460b06893fa040ff066   Mac破解版软件网址

  10. WIN7搭建ASP站点

    在WIN7配置IIS用于搭建ASP站点(非ASP.NET) ,仅安装.配置必要文件. 1.安装IIS管理工具,用于支持静态页面. 2.添加匿名访问权限. 搭建站点指定到特定文件夹,浏览静态页面会报如下 ...