vue 项目中笔记-持续更新
9.class常用操作:
8.watch监听属性,顾名思义需要先在data里面定义了才能监听到 ; computed 计算属性,不能在data中定义,
watch中能执行异步操作例如 setTimeout函数,computedu不可以 会返回undefined,只能直接return;
简写形式都是不需要改变数据,只获取数据才用,否则都需要写出复杂格式
<template>
<div>
<p>mesage:{{newMessage}}</p>
<p>reversed message:"{{reverMessage}}"</p>
<button @click="changeInfo">改变info</button>
<ul>
<li v-for="item in list">{{item.name}}--{{item.age}} </li>
</ul>
</div>
</template> <script>
export default{
name:"myCom",
data(){
return{
message:'hellow',
message2:'world',
info:{
a:1,
b:'zhangsan'
},
list:[{
name:'zhangsa',
age:12
},{
name:'lisi',
age:12}], }
},
watch:{
info:{//对象 改变对象的属性触发,简写是不会触发的
deep:true,//监视多层数据改变,针对对象和数组
handler(current){
console.log('info发生了改变',current);
},
},
list:{//数组 改变数组里面的某个值触发
deep:true,
handler(current){
console.log('list发生了改变',current);
}
},
message(current,old){ //简写 不改变数据时这样写
console.log('info发生了改变',current,old);
},
},
computed:{
reverMessage:function(){//简写形式
return (this.message||'').split("").reverse().join('')
},
newMessage:{ //需要修改数据的时候要这样写
get(){
return this.message+this.message2;
},
set(v){
return v;
}
}
},
methods:{
changeInfo(){
this.info.a = this.info.a+1;
this.message = 'name';
this.list[1].age=this.list[1].age+1;
},
}, }
</script> <style>
</style>
------------------------------------------------------------------------------------从这开始倒着写-----------------------------------------------------------------------------
1.路由跳转:非view页面要实现跳转:
2. nextTick:在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM。
pick:从 object 中选中的属性的对象。使用需要先引入:import pick from 'lodash.pick'
this.$nextTick(() => {
this.form.setFieldsValue(pick(this.model,'userName','inDate','outDate','userLevel','userTag','extra1','extra2'))
//时间格式化
});
3.props数据类型:Number、String、Boolean、Object、Array、Date、Function、Symbol
// 简单语法
Vue.component('props-demo-simple', {
props: ['size', 'myMessage']
})
// 对象语法,提供验证
Vue.component('props-demo-advanced', {
props: {
// 检测类型
height: Number,
// 检测类型 + 其他验证
age: {
type: Number,
default: 0,
required: true,
validator: function (value) {
return value >= 0
}
}
}
})
4.<router-link></router-link> 添加事件监听函数
<router-link
:to="{ path: tag.path, query: tag.query, fullPath: tag.fullPath }"
:title="tag.title"
tag="span"
@click.native="showCurrentPage(tag)" //tag为当前的路由
>{{tag.title}}</router-link>
5.模板字符串换行显示 :
例如:let a =`aaaaa
bbbb`;
1.使用textarea标签保留样式
2.pre标签 :被包围在 pre 元素中的文本通常会保留空格和换行符
其他的标签暂未发现有保留的功能,当a有空格的时候是有空格的样式展示出来且只有一个空格
6.动态组件切换 简单例子两个组件相互切换:
<template>
<div>
<keep-alive>
<!-- 动态组件 -->
<component :is="componentName"></component> <!-- <my-com v-if="name=='myCom'"></my-com>
<my-com-two v-show="name=='myComTwo'"></my-com-two> -->
</keep-alive>
<button @click="changeCom">切换组件</button>
</div>
</template> <script>
import myCom from './myCom.vue' //组件一
import myComTwo from './myComTwo.vue' //组件二
export default{
name:"activeCom",
components:{myCom,myComTwo},
data:function(){
return{
componentName:myCom,
name:'myCom'
}
},
methods:{
changeCom(){
let {name} = this;
this.componentName = name=='myCom'?myComTwo:myCom;
this.name= name=='myCom'?'myComTwo':'myCom';
console.log("com:",this.componentName);
}
}
}
</script> <style>
</style>
7.beforeDestroy和destroyed触发条件:关闭当且页面或者关闭路由,但是v-if或者v-show这样的切换都不会触发这两个生命周期
vue 项目中笔记-持续更新的更多相关文章
- vue 项目中的坑 在项目中遇到 持续更新ing
1.vue2.0 不支持 v-html 后绑定的内容使用过滤,可是有时候过滤必须使用-----------解决:通过methods中定义方法 然后 v-html='myMethods(string)' ...
- webpack4搭建Vue开发环境笔记~~持续更新
项目git地址 一.node知识 __dirname: 获取当前文件所在路径,等同于path.dirname(__filename) console.log(__dirname); // Prints ...
- Vue 项目优化,持续更新...
一.减少打包的体积 通过vue-cli 初始化项目后,使用 npm run build 生成的JS文件往往会很大,加载时间过长导致页面长时间白屏,所以我们尽可能的使用一下方法来减少打包体积. 1.1 ...
- 【前端面试】Vue面试题总结(持续更新中)
Vue面试题总结(持续更新中) 题目参考链接 https://blog.csdn.net/weixin_45257157/article/details/106215158 由于已经有很多前辈深造VU ...
- vue项目中使用bpmn-流程图json属性转xml(七篇更新完成)
内容概述 本系列“vue项目中使用bpmn-xxxx”分为七篇,均为自己使用过程中用到的实例,手工原创,目前陆续更新中.主要包括vue项目中bpmn使用实例.应用技巧.基本知识点总结和需要注意事项,具 ...
- 前端学习笔记系列一:10整体移动vscode代码块、VSCode 使用 stylus,配置格式化设置、在vue项目中引入bootstrap
1.整体移动vscode代码块 凭借操作的经验我们能够轻松地知道将代码整体往右移只需选中代码按Tab键即可.其实往左移也很简单: 选中之后按下 shift+Tab键 即可. 2.VSCode 使用 s ...
- BLE资料应用笔记 -- 持续更新
BLE资料应用笔记 -- 持续更新 BLE 应用笔记 小书匠 简而言之,蓝牙无处不在,易于使用,低耗能和低使用成本.'让我们'更深入地探索这些方面吧. 蓝牙无处不在-,您可以在几乎每一台电话.笔记本电 ...
- vue项目中遇到的那些事。
前言 有好几天没更新文章了.这段实际忙着做了一个vue的项目,从 19 天前开始,到今天刚好 20 天,独立完成. 做vue项目做这个项目一方面能为工作做一些准备,一方面也精进一下技术. 技术栈:vu ...
- Vue项目中GraphQL入门学习与应用
1.GraphQL是什么,能干什么? 正如官网所说,GraphQL是一种用于API查询的语言.Facebook 的移动应用从 2012 年就开始使用 GraphQL.GraphQL 规范于 2015 ...
- vue项目中 axios 和Vue-axios的关系
文章收集于:https://segmentfault.com/q/1010000010812113 在vue项目中,会经常看到如下代码: 今天看到有些项目是这样写的,就有点看不懂了. ----解 ...
随机推荐
- 配置tomcat 服务 启动模式
1配置Tomcat的环境变量,其步骤如下: 计算机右击属性,打开环境变量---系统变量---新建变量名:CATALINA_HOME,变量值为:D:\Program Files\Apache Softw ...
- CH582m串口透传程序
目录 参考了沁恒官网22年1月更新的CH583EVT包中的UART1例程 功能:上位机通过串口1发送指令规定串口2和3的波特率,实现串口2和3之间的数据透传 担心串口3的接收中断会被串口2的发送中断打 ...
- 使用fopen,fscanf等函数报安全性问题的错误,unsafe...
方法一:项目-属性-C/C++-预处理器定义,添加_CRT_SECURE_NO_WARNINGS. 方法二:使用fopen_s,fscanf_s等安全函数.
- Java-获取真实用户ip
1 import common.util.StringUtil; 2 import org.springframework.web.bind.annotation.ModelAttribute; 3 ...
- 【三维重建】Ubuntu20.04进行RealSenseD435环境配置及初步使用
一.环境配置 github上面的教程:https://github.com/IntelRealSense/librealsense/blob/master/doc/distribution_linux ...
- ES-增删改查
写作目的 供想了解ES数据操作的伙伴学习ES的CRUD操作. 测试环境 ES7.8.1 postman 创建索引库 // PUT请求 localhost:9200/test_alert { " ...
- Stream流、lambda表达式、方法引用、构造引用
函数式接口 函数接口为lambda表达式和方法引用提供目标类型,就是提供支持的接口里面只有且必须只有一个抽象方法, 如果接口只有一个抽象方法,java默认他为函数式接口 @FunctionalInte ...
- 实验1task3
<实验结论> #include <stdio.h> #include <stdlib.h> int main() { int a, b, t; a = 3; b = ...
- yolov5查看训练日志图片和直方图(包括稀疏训练bn直方图)
0.D:\code\codePy\yolov5-6.1\runs\train\exp25文件夹下有 events.out.tfevents.1675823043.DESKTOP-ACC9FL4.521 ...
- 在windows上搭建spark遇到的问题
报错如下: The root scratch dir: /tmp/hive on HDFS should be writable. Current permissions are: --------- ...