【VUE】使用问题记录

=====================================================================

1、Vue.nextTick 修改数据之后更新DOM

2、修改了属性,视图没有刷新,或使用了this.$forceUpdate()

3、鼠标over和out

4、MSBUILD : error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”

5、div 滚动条滚动到最底部

6、数组对象里的图片修改后不显示

7、对象copy

8、子组件使用父组件的变量

9、监听 window.open 关闭

10、图片路径引入问题

生命周期图

=====================================================================

1、Vue.nextTick 修改数据之后更新DOM

Vue.nextTick(callback)

在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM。

this.$nextTick(()=>{
// todo
});

Vue.nextTick(()=>{
// todo
});

2、修改了属性,视图没有刷新,或使用了this.$forceUpdate()

如果你发现你自己需要在 Vue 中做一次强制更新,99.9% 的情况,是你在某个地方做错了事。

你可能还没有留意到数组或对象的变更检测注意事项,或者你可能依赖了一个未被 Vue 的响应式系统追踪的状态。

然而,如果你已经做到了上述的事项仍然发现在极少数的情况下需要手动强制更新,那么你可以通过 $forceUpdate 来做这件事。

引起这个问题的大部分原因是因为属性在某种情况下变为非响应式的

比如,从后台返回的对象结构中没有某个属性,或者这个属性不是在data中定义的,而是后来加的。

https://cn.vuejs.org/v2/guide/components-edge-cases.html#强制更新

对象变为非响应式

https://cn.vuejs.org/v2/guide/list.html#注意事项

对象检测

https://cn.vuejs.org/v2/guide/list.html#对象变更检测注意事项

响应式原理

https://cn.vuejs.org/v2/guide/reactivity.html#ad

添加对象属,指定属性和值

Vue.set(vm.user, 'age', 27) 或者 vm.$set(vm.user, 'age', 27)

要添加数组,指定索引和对象

let item = {
value: '10',
label: '张三'
}
this.$set(this.myArray, 1, item);

3、鼠标over和out

@mouseover="imageMouseOver(o.url)"
@mouseout="imageMouseOut(o.url)"

 4、MSBUILD : error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”

以管理员方式运行命令提示符,全局安装windows构建工具

npm install -–global -–production windows-build-tools

5、div 滚动条滚动到最底部

this.$nextTick(function(){
let div = document.getElementById('divIdxyz');
div.scrollTop = div.scrollHeight;
})

6、数组对象里的图片修改后不显示

引起这个问题的原因是,直接把数组里原来的对象替换成了新对象,导致对象成为了非响应式对象,解决办法是不要替换对象而是修改数组中对象的属性值就可以。

7、对象copy

借助json完美实现对象copy

var a = {name: 'tom', age: 25, address: ['beijing','hangzhou']}
var b = JSON.parse(JSON.stringify(a))

8、子组件使用父组件的变量

https://cn.vuejs.org/v2/api/#provide-inject

父组件 provide 一个变量,子组件 inject 变量

// 父级组件提供 'foo'
var Provider = {
provide: {
foo: 'bar'
},
// ...
} // 子组件注入 'foo'
var Child = {
inject: ['foo'],
created () {
console.log(this.foo) // => "bar"
}
// ...
}

 9、监听 window.open 关闭

btnUpdate(row){
this.windowObject = window.open('xxxxxx');
this.loopObject = setInterval(this.waitWindowClose, 1000);//注意不能加括号
},
waitWindowClose() {
if(this.windowObject.closed) {
clearInterval(this.loopObject);
this.windowObject = undefined;
this.loopObject = undefined;
this.reloadList();
}
}

参考: https://www.cnblogs.com/jin-zhe/p/10001236.html

10、图片路径引入问题

动态引入图片。图片文件放入assets目录中

方式一 import,需要在data中注册一下

import logo from '@/assets/img/logo.png';
data() {
return {
logo,
}
}

方式二 require

data() {
return {
logo: require("@/assets/images/avatar.png"),
}
}
<img :src="logo">

鼠标划过修改图片示例

data() {
return {
mouseOutMoreImg: require('@/assets/out.png'),
mouseOverMoreImg: require('@/assets/over.png'),
waitMoreImg: require('@/assets/out.png')
}
}
method() {
waitOver() {
this.waitMoreImg = this.mouseOverMoreImg;
},
waitOut() {
this.waitMoreImg = this.mouseOutMoreImg;
}
}
<img :src="waitMoreImg" class="img" @click="handleMore" @mouseover="waitOver" @mouseout="waitOut">

======================================================================

生命周期图

【VUE】使用问题记录的更多相关文章

  1. vue.js学习记录

    vue.js学习记录 文章已同步我的github笔记https://github.com/ymblog/blog,欢迎大家加star~~ vue实例 生命周期 beforeCreate:不能访问thi ...

  2. vue 自学笔记记录

    vue 自学笔记(一): 知识内容:  安装vue ,创建vue实例,安装第一个组件,单项数据流 https://www.cnblogs.com/baili-luoyun/p/10763163.htm ...

  3. vue使用tips记录

    用vue已经很久啦,这里记录一下一些我觉得比较实用的小tips:

  4. vue 组件发布记录

    好久没做独立的 vue 组件了,最近突然想把一个常用的 vue 组件打成一个 npm 包,方便使用.好久不用,发现已经忘记环境怎么搭建.翻看以前的组件,才慢慢回想起来,中间还出现些错误.在这记录下开发 ...

  5. Vue 使用History记录上一页面的数据

    UI Mvvm 前端数据流框架精讲 Vue数据双向绑定探究 面试问题:Vuejs如何实现双向绑定 数据双向绑定的探究和实现 需求 从列表页的第二页进入详情页,返回时列表页仍然显示在第二页: 从列表页的 ...

  6. [vue折线图] 记录SpringBoot+Vue3.0折线图订单信息展示

    因公司业务需求,需要做一份订单相关的折线图, 如果其中有一天没有订单的话,这一天就是空缺的,在绘制折线图的时候是不允许的,所有要求把没有订单数据的日期也要在图表显示. 使用技术vue3.0+sprin ...

  7. vue框架-学习记录

    前段时间在做vue项目时,遇到挺多问题,想简单总结一下: 1.关于父组件,子组件的通信 网上有很多这方面的讲解,讲解也比较细致,我主要总结了自己在项目中需要的: [1]父组件-子组件 也就是" ...

  8. vue踩坑记录:[Vue warn]: $attrs is readonly.

    今天在用element-ui的DatePicker日期选择器的时候,发现每当点击一次这个组件,控制台就会报警告`[Vue warn]: $attrs is readonly`,但是也不影响实际操作效果 ...

  9. Js 框架之Vue .JS学习记录 ① 与Vue 初识

    目录 与 Vue.js 认识 VUE.JS是个啥?有啥好处? Vue 的目标 战前准备  VUE.JS环境 VUE.JS 尝试一下,你就明白 第一步 实例化VUE 对象 第二步VueAPP 调用数据 ...

  10. Vue.js简单记录

    官网:https://cn.vuejs.org/ https://cn.vuejs.org/v2/api/#methods v-bind 缩写 <!-- 完整语法 --> <a v- ...

随机推荐

  1. nyoj 975-关于521 (EOF)

    975-关于521 内存限制:64MB 时间限制:1000ms 特判: No 通过数:5 提交数:46 难度:2 题目描述: Acm队的流年对数学的研究不是很透彻,但是固执的他还是想一头扎进去. 浏览 ...

  2. HTML5之worker开启JS多线程模式及window.postMessage跨域

    worker概述 worker基本使用 window下的postMessage worker多线程的应用 一.worker概述 web worker实际上是开启js异步执行的一种方式.在html5之前 ...

  3. 力扣(LeetCode)移除链表元素 个人题解

    删除链表中等于给定值 val 的所有节点. 这题粗看并不困难,链表的特性让移除元素特别轻松,只用遇到和val相同的就跳过,将指针指向下一个,以此类推. 但是,一个比较麻烦的问题是,当链表所有元素都和v ...

  4. Windows 10上源码编译glog和gflags 编写glog-config.cmake和gflags-config.cmake | compile glog and glags on windows from source

    本文首发于个人博客https://kezunlin.me/post/bb64e398/,欢迎阅读! compile glog v0.3.5 and glags on windows from sour ...

  5. 20191031-3 beta week 1/2 Scrum立会报告+燃尽图 01

    此作业要求参见[https://edu.cnblogs.com/campus/nenu/2019fall/homework/9911] 一.小组情况 队名:扛把子 组长:孙晓宇 组员:宋晓丽 梁梦瑶 ...

  6. 小白学 Python 爬虫(6):前置准备(五)爬虫框架的安装

    人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 小白学 Python 爬虫(3):前置准备(二)Li ...

  7. 图解 Spring:HTTP 请求的处理流程与机制【5】

    5. HTTP 请求处理相关配置文件说明 HTTP 请求穿越的整个空间是分层的,包括:Web 容器.Web 应用.Spring 框架等,它们每层都是通过配置文件配置初始化的,这是一种松耦合的架构设计. ...

  8. 数据表与简单java类——多对多映射

    给定一张Meber和Product表,得到如下信息: 1.获取一个用户访问的所有商品信息 2.获取一个商品被哪些用户浏览过的信息 package Mapping_transformation; cla ...

  9. Django3.0 异步通信初体验

    此前博主曾经写过一篇博文,介绍了Django3.0的新特性,其中最主要的就是加入对ASGI的支持,实现全双工的异步通信. 2019年12月2日,Django终于正式发布了3.0版本.怀着无比的期待,我 ...

  10. Maven搭建SpringMvc

    Maven搭建SpringMvc,只需跟着一步步操作 项目结构 1 创建Maven项目 index,jsp报错不用管,配置完pom就好了,也可以直接删除掉 2 pom.xml添加依赖 <depe ...