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项目中,会经常看到如下代码: 今天看到有些项目是这样写的,就有点看不懂了. ----解 ...
随机推荐
- js获取的 后端的列表。
1.引号被转码 处理办法 {% autoescape off %} var tmp = '{{ data1 }}'; var tmp = '{{ data2 }}'; {% endautoescape ...
- Django路由重定向
路由重定向又称HTTP协议重定向,也可以称为网页跳转,它对应的HTTP状态码为301.302.303.307.308. 网页重定向就是在浏览器访问某个网页的时候,这个网页不提供响应内容,而是自动跳转到 ...
- npm 局部安装 jbrowse
#此处不要加 -g参数 , -g 是全局安装 npm install @jbrowse/cli #用npx 才能使用这个包,无法按照官方文档直接使用 npx jbrowse --version
- uwsgi部署flask,flask_apscheduler任务遇到各种问题解决
背景:最近在做的全域事件项目,快要靠近尾声了,需要用到uwsgi部署至生产环境,由于之前是debug模式,运行项目也是通过命令 python manager.py runserver (manage是 ...
- 3、k8s 核心实战
7 kubernets核心实战 7.1 资源创建方式 命令行 yaml 7.2 namespace 名称空间来隔离资源 命令行方式 kubectl create ns hello kubectl de ...
- GPS网络授时仪(网络授时服务器)成功投运攀枝花市中西医结合医院
GPS网络授时仪(网络授时服务器)成功投运攀枝花市中西医结合医院 GPS网络授时仪(网络授时服务器)成功投运攀枝花市中西医结合医院 北京华人开创科技发展有限公司 技术交流15901092122岳峰 概 ...
- 关于easyocr、paddleocr、cnocr之比较
关于easyocr.paddleocr.cnocr之比较 EasyOCR 是一个使用 Java 语言实现的 OCR 识别引擎(基于Tesseract).借助几个简单的API,即能使用Java语言完成图 ...
- 题解 UVA10859 【Placing Lampposts】
交了N次,重构一次代码终于过了..... 题意:一片森林,1.输出占领所有边需要的最小的路灯个数 2.输出两端点均被占领的边的条数 3.只有一端被占领的边的条数 还是比较简单的 开始的时候思路不够清晰 ...
- 解决在宝塔面板IIS服务器上部署svg/woff/woff2字体的问题
部署网站的字体和服务器IIS有什么关系?如果你的职责只限于一名前端开发,那么你可能很"幸福"地与这些问题擦肩而过,浑然不觉.可是本人一直都是孤军奋战,连开发环境都要自己搭建,这次又 ...
- 实验5:开源控制器实践POX
一.基础实验 建立拓扑: sudo mn --topo=single,3 --mac --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk, ...