2021/3/25
vue的基本使用
<head>
<!-- 1.先引入vue核心文件-->
<script src="vue.js"></script>
</head>
<body>
<!--在el属性对象的标签中 填写正确的vue语法展示或者控制数据-->
<div id="app">
{{message}}
</div>
<script>
//2.对vue核心对象vm进行实例化
var vm=new Vue({
el:"#app",//接下来vue要操作的元素的选择符
data:{//保存一些前端使用的数据
message:"hello world",
},
});
</script>
</body>
JQuery与vue定位不一样
jquery获取元素完成特效
vue的定位是方便操作和控制数据完成特效
vue的使用三个注意事项
1.一个html页面中可以存着多个vue实例对象 但是实例对象的变量名唯一
2.js所有变量和语法区分大小写 new Vue()
3.建议实例化vue对象的代码写在body的最后面 免得出现html元素无法获取的错误出现
django MVT模型 model view template
vue M-V-VM思想 Model-View-ViewModel 双向数据绑定
<!--V.View视图模板-->
<div id="app">
<input v-model="message"><br>
{{message}}
</div>
<script>
//new Vue VM对象 负责时刻保证视图模板中的数据和data里面的数据一致
var vm=new Vue({
el:"#app",
data:{//M.Model 模型
message:"hello world",
},
});
</script>
网页控制台输入
vm
vm.message
vm.message="你好"
v-if v-model v-for
<div id="d1">
<a :href="url">百度</a>
</div>
<script>
var vm=new Vue({
el:"#d1",
data:{
url:"http://www.baidu.com",
},
})
</script>
显示密码
<div id="d1">
<a :href="url">百度</a><br>
密码: <input :type="type" v-model="password"><button @click="change">{{msg}}密码</button>
</div>
<script>
//data里面的属性 和methods里面的方法都会被加载到vm对象里面充当属性和方法
var vm=new Vue({
el:"#d1",
data:{
type:"password",
password: "",
url:"http://www.baidu.com",
},
methods:{
change(){//change:function(){的简写
if(this.type=="password"){this.type="text",this.msg="显示"}
else{this.type="password",this.msg="隐藏"}//这里的this表示vm对象
}
}
})
</script>
样式操作
<div id="box">
<div style="color:red;">这是普通样式</div>
<div :style="{color:fc,backgroundColor:gc}">vue修改样式值</div>
<div :style="sty1">vue修改样式值 值是对象名</div>
<div :style="[sty1,sty2]">vue修改样式值 值是数组</div>
</div>
<script>
var vm=new Vue({
el:"#box",
data:{
fc:"red",
gc:"purple",
sty1:{
color:"yellow",
backgroundColor:"green",
},
sty2:{
fontSize:"32px",
border:"1px solid #fff",
},
}
})
</script>
列表循环
<div id="box">
<table border="1" align="center" width="600px">
<tr>
<th>序号</th>
<th>商品编号</th>
<th>商品标题</th>
<th>商品价格</th>
<th>商品数量</th>
</tr>
<tr v-for="goods ,index in goods_list">
<td>{{index+1}}</td>
<td>{{goods.id}}</td>
<td>{{goods.title}}</td>
<td>{{goods.price}}</td>
<td>{{goods.num}}</td>
</tr>
</table>
</div>
<script>
var vm=new Vue({
el:"#box",
data:{
goods_list:[
{id:10,title:"商品1",price:100,num:65},
{id:11,title:"商品2",price:120,num:45},
{id:13,title:"商品3",price:130,num:15},
{id:14,title:"商品4",price:50,num:23},
{id:15,title:"商品5",price:70,num:75},
],
}
})
</script>
v-show与v-if的区别
1.v-show 后面不能v-else或v-else-if
2.v-show 隐藏元素时 使用的是display:none来隐藏的,而v-if 直接从html 文档中移除元素[dom操作中的remove]
<div id="box">
<p v-show="is_show">一段文本</p>
<p v-if="is_show">一段文本2</p>
</div>
<script>
var vm=new Vue({
el:"#box",
data:{
is_show:true,
}
})
</script>
jQuery和vue定位不一样
jQuery的定位是获取元素完成特效
vue的定位是方便操作和控制数据和完成特效
vue 使用两种模式 脚本化导入和组件化开发
1.纯文本数据{{}} 2.表单标签中输出表单的值 v-model
3.如果输出的内容含html代码则需要v-html
过滤器 全局过滤器 局部过滤器
<p>{{price|format}}</p>//过滤器的使用
//全局过滤器
Vue.filter("过滤器函数名",function(money){
return money.toFixed(2);js中提供toFixed方法可以保留两位小数
})
全局过滤器可以单独写在一个文件里面 外部进行调用
局部过滤器 针对当前Vm 对象中使用
var vm=new Vue({
el:"#box",
data:{
price:7.899,
},
filters:{
format(money){
return money.toFixed(2)+"元";
}
}
})
计算属性 相当于创建一个新的变量保存数据计算的结果
<div id="box">
<p><input type="text" v-model="num1">+ <input type="text" v-model="num2">=
<span>{{total}}</span>
</p>
</div>
<script>
var vm=new Vue({
el:"#box",
data:{
num1:0,
num2:0,
},
computed: {
total(){
return parseFloat(this.num1)+parseFloat(this.num2);
}
}
})
</script>
对于js而言用户在表单中输入的所有数据都是字符串
parseInt 把数据转换成整数
parseFloat 把数据转换成浮点数
监听属性 监听属性变化
watch 监听属性 监听指定变量的值是否发生变化 当值发生变化时 调用对应的方法
<button @click="num++">赞{{num}}</button>
watch:{
num(v1,v2){
if(this.num>5){
this.num=5;
}
console.log(this.num,"修改前",v2,"修改后",v1);
}
}
vue生命周期
created(){//实现到服务端获取页面数据}
mounted(){//修改页面内容[页面特效]}
vue本质js
事件冒泡 事件特效 指js中子元素的事件触发以后 会导致父级元素的同类事件一并被触发到
事件冒泡有好处也有坏处
<div id="box">
<div class="box2" >
<div class="box1" ></div>
</div>
</div>
<script>
var box1=document.getElementsByClassName("box1")[0];
var box2=document.getElementsByClassName("box2")[0];
box1.onclick=function (event) {//事件对象
alert("点击了box1")
console.log(event);
event.stopPropagation();//阻止事件冒泡
};
box2.onclick=function () {
alert("点击了box2")
};
</script>
return false 是jQuery里面的方案
<ul id="app">
<li>1111111</li>
<li>2222222</li>
<li>3333333</li>
<li>4444444</li>
<li>5555555</li>
</ul>
<script>
//批量元素绑定 可以通过事件委托来提升性能
var list=document.getElementById("app").children;
for(var i in list){
list[i].onclick=function () {
console.log(this.innerHTML);
}
}
</script>
//事件委托提升性能
var ul=document.getElementById("app");
ul.onclick=function (event) {
var self=event.target;
console.log(self.innerHTML)
}
Vue中阻止事件冒泡
<style>
.box1{
width:200px;
height:200px;
background-color: pink;
margin: auto;
}
.box2{
width:400px;
height:400px;
background-color: wheat;
padding-top: 50px;
}
</style>
<div id="app">
<div class="box2" @click="show('点击了box2')">
<div class="box1" @click.stop="show('点击了box1')"></div>
</div>
</div>
<script>
//vue本质就是js 所有vue中的事件操作也会存在冒泡现象
//可以使用辅助指令 @click.stop来阻止事件冒泡
var vm=new Vue({
el:"#app",
methods:{
show(message){
alert(message);
}
}
})
</script>
阻止页面刷新
<div id="app">
<a :href="url" @click.prevent>百度</a>
</div>
<script>
var vm=new Vue({
el:"#app",
data:{
url:"http://www.baidu.com"
},
})
</script>