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项目中,会经常看到如下代码: 今天看到有些项目是这样写的,就有点看不懂了. ----解 ...
随机推荐
- 2022-05-06内部群每日三题-清辉PMP
1.一个项目正处于执行阶段,一些可交付成果已经准备好交给客户.团队成员希望快速交付这些可交付成果,以节省时间并获得资金.若要实现这个目标,就必须消除质量控制相关的任务. 项目经理应该怎么做? A.让团 ...
- io流转换为Multipart文件
io流转换为Multipart文件 个人的话是运用到了minio文件服务器保存文件,前端(vue)异步上传文件后,由于要提升用户体验效果,先上传文件到后台服务器,返回视频在文件服务器的link()参数 ...
- 禁止Edge升级
管理员命令行运行: 用法:EdgeChromium_Blocker.cmd [<machine name>] [/B][/U][/H] 1.本机禁用更新: EdgeChromium_Blo ...
- ElasticSearch (Es) 分组查询 记录
首先表对应的实体类型: public class bm_info{ /// <summary> /// 单位 /// </summary> public string sou ...
- slitaz中tazpkg更改软件源
在tazpkg手册中可以查到保存tazpkg软件源网址的文件,/var/lib/tazpkg/mirror
- Flutter tab切换保持页面状态的两种方法
当通过底部tabBar将页面在"首页"和"分类"之间进行切换的时候,每一次进入页面的时候该页面的数据都会重新加载.那么如何让页面保持原来的状态,而不是每次都要重 ...
- VM虚拟机的创建和CentOS 7的安装
1.vm和CentOS的下载. 一:vm和CentOS的下载,这是创建虚拟机和CentOS安装的必要条件. 2.vm虚拟机的创建. 一:打开vm软件界面,会看到虚拟机的字,点击虚拟机开始创建虚拟机.二 ...
- 27_wbpack_自定义Plugin
Tapable 要想学会自定义Plugin就要先了解Tapable这个库 在我们的wbpack中有两个非常重要的两个类Compiler和Compilation 他们是通过注入插件的方式,来监听webp ...
- urllib编码问题踩坑
今天在使用python的urllib对网页进行爬取的时候,中文一直出现错误 UnicodeEncodeError: 'ascii' codec can't encode character '\u62 ...
- 日記かな、自分のサーバ作りの?(01、try…catch…の問題)
今日まだ終わらないうちに.昼間から出会ったbugについて.取りまとめましょう. 一応try-catch-にかかわる問題かな- try(do something){ }catch{ } と try(){ ...