一、Vue基础
Vue.js - 渐进式 JavaScript 框架 | Vue.js
- 导入开发版本的Vue.js
- 创建Vue实例对象,设置el属性和data属性
- 使用简洁的模板语法把数据渲染到页面上
1、el挂载点(建议使用id选择器)
<div id="app" class="app">
{{message}}
</div>
<script>
var app = new Vue({
el:"#app",//el:".app",
data:{
message:"hello vue"
}
})
</script>
2、data数据对象
<div id="app">
{{ message }}
<h2> {{ school.name}}</h2>
<li>{{ campus[0]}}</li>
<li>{{ campus[3]}}</li></ul>
</div>
<script>
var app = new vue({
el:"#app",
data:{
message:"hello vue!",
school:{
name:"zhang",
mobile: "400-618-909e"
},
campus:["北京","上海","广州","深圳"]
}
})
</script>
- Vue中用到的数据定义在data中
- data中可以写复杂类型的数据
- 渲染复杂类型数据时,遵守js的语法即可
二、本地应用-Vue指令
1、v-text
设置标签的文本值(textContent)
<div id="app">
<h2 v-text="message"></h2>
<h2>你好{{message+"!"}}</h2>
</div>
<script>
var app = new Vue({
el:"#app",
data:{
message:"hello vue"
}
})
</script>
2、v-html
设置标签的innerHTML
<div id="app">
<p v-html="content"></p>
</div>
var app = new Vue({
el:"#app",
data:{
content:"<a href='#'>黑马程序员</a>"
}
})
- v-html指令的作用是:设置元素的innerHTML
- 内容中有html结构会被解析为标签
- v-text指令无论内容是什么,只会解析为文本
3、v-on基础
为元素绑定事件
<div id="app">
<input type="button" value="事件绑定" v-on:click="方法">
<input type="button" value="事件绑定" @click="方法">
<input type="button" value="事件绑定" @click="doit(p1,p2)">
</div>
var app = new Vue({
el:"#app",
methods:{
doit:function(){
//逻辑
},
doit:function(p1,p2){
//逻辑
}
}
})
4、v-show
根据表达值的真假,切换元素的显示和隐藏
<div id="app">
<img src="地址" v-show="isShow">
<img src="地址" v-show="age>=18">
</div>
var app = new Vue({
el:"#app",
data:{
isShow:true //false
age:16
}
})
5、v-if
根据表达值的真假,切换元素的显示和隐藏(操纵dom元素)
<div id="app">
<p v-if="true">我是一个p标签</p>
<p v-if="isShow">我是一个p标签</p>
<p v-if="表达式">我是一个p标签</p>
</div>
var app = new Vue({
el:"#app",
data:{
isShow:false
}
})
6、v-bind
设置元素的属性
<div id="app">
<img v-bind:src= "imgSrc" >
<img v-bind:title= "imgtitle+'!'" >
<img class="isActive?'active':''">
<img class="{active:isActive}" >
</div>
var app = new Vue({
el:"#app",
data:{
imgSrc:"图片地址",
imgTitle:"标题",
isActive:false
}
})
7、v-for
根据数据生成列表结构
<div id="app">
<ul>
<li v-for="(item,index) in arr" :title="item">
{{index }}{{ item }}
</li>
<li v-for="(item,index) in objArr">
{{ item.name }}
</li>
</ul>
</div>
var app = new Vue({
el: "#app",
data: {
arr: [1, 2,3,4, 5],
objArr: [
{ name: "jack" },
{ name: "rose" }
]
}
})
8、v-model
获取和设置表单元素的值(双向数据绑定)
<div id="app">
<input type="text" v-model="message"/>
</div>
var app = new Vue({
el: "#app",
data:{
message:"hello"
}
})
三、网络应用
1、axios基本使用
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
axios.get(地址?key=value&key2=value2).then(function(response){},function(err){ })
axios.post(地址,{key:value,key2:value2}).then(function(response){},function(err){ })
document.querySelector(".get").onclick = function () {
axios.get( "https://autumnfish.cn/api/joke/list?num=3")
.then(function (response){
console.log(response);
},function(err){
console.log(err);
})
}