vue入门

一、初始Vue

  1. 初始Vue
    第一步:给Vue准备一个容器:

<div id="app">

<h2>{{name}}</h2>
<h2>{{age}}</h2>
</div>
第二步:创建Vue实例:

// 不允许 vue-devtools 检查代码
Vue.config.devtools = false
// vue 在启动时不显示生产提示
Vue.config.productionTip = false

// 初始化一个Vue实例,在创建Vue实例时,需要给Vue传递一个配置选项,该配置选项是一个对象
let vm = new Vue({
// el选项,指定当前Vue实例,操作的容器
el:'#app',
// data选项,用于存储当前Vue实例管理的数据
// data选项里面管理的数据,会被添加到Vue实例身上,这里就是vm身上。
// data选项里面管理的数据,其实会被Vue实例身上的_data进行代理;并将代理过后的数据再添加到Vue实例身上,方便直接调用。
data:{
name:'王瑞',
age:20
}
})

  1. Vue的响应式原理
    // 代理对象的基本理解:
    /* let data = {
    name:'兵哥',
    age:18
    }
    // 因为对象是引用类型,在传递时,传的是地址
    let _data = data;
    // 操作_data,真正改变的是data,此时就可以将_data当做是data的代理对象。
    _data.name = '王瑞'
    _data.age = 30
    console.log(data); */
    console.log('-------------------------------');

// 如何给对象添加成员
let obj = {}
// 方式1:对象名.属性的方式,给对象添加成员
obj.name = '吴亦凡'
// 方式2:对象名['属性名']的方式,给对象添加成员
obj['age'] = 30
// 方式3:通过Object对象的defineProperty方法,给指定的对象添加指定的属性
// 这种方式,给对象添加成员,尽管繁琐,但是可以配置更多的功能。
// 默认添加的属性是不允许删除的,如果要允许删除,就需要添加configurable配置。
// 默认添加的属性是不允许枚举的,所谓枚举指的就是遍历。
Object.defineProperty(obj,'sex',{
// 属性值
value:'男',
// 属性允许被删除
configurable:true,
// 属性允许被枚举
enumerable:true
})
// 遍历出对象的所有属性名称
for(let key in obj){
console.log(key);
}

// delete关键字,用于删除对象身上的指定成员
delete obj.name
delete obj.sex
console.log(obj);
console.log('-------------------------------');

// 那么Vue的响应式原理,就用到了Object.defineProperty,给代理对象添加属性。
// 01.我们先定义一份原始数据,也就是被代理对象。
let data = {
name:'兵哥',
age:18
}
// 02.再定义一个空的代理对象
let _data = {}
// 03.使用Object.defineProperty给代理对象添加属性
Object.defineProperty(_data,'name',{
// get方法,用于返回属性的值,当使用到_data对象里面的name属性获取值时,就会执行get方法
get(){
return data.name
},
// set方法,用于设置属性的值,当使用到_data对象里面的name属性并给它赋值时,就会调用set方法
set(val){
data.name = val
// 当监听到数据发生变化时,重新渲染DOM
readerDOM()
}
})
Object.defineProperty(_data,'age',{
get(){
return data.age
},
set(val){
data.age = val
readerDOM()
}
})

// 渲染DOM更新的方法
function readerDOM(){
document.getElementById("name").innerHTML = data.name
document.getElementById("age").innerHTML = data.age
}
readerDOM()

  1. Vue的常用指令
    <div id="app">

    <h2>{{name}}</h2>



    <input type="text" v-bind:value="name" v-on:input="setName">


    <h2>{{address}}</h2>



    <input type="text" :value="address" @input="address=$event.target.value">


    <h2>{{hobby}}</h2> <input type="text" v-model="hobby">
    </div>
    // 实例化一个Vue对象
    let vm = new Vue({
    el:'#app',
    // data选项,可以是一个对象,也可以是一个方法,由方法返回一对象。
    data() {
    return {
    name:'兵哥',
    address:'南京',
    hobby:'敲代码'
    }
    },
    // methods选项,里面定义的是Vue管理的方法
    methods: {
    // 该方法更新name属性值
    // 注意:在调用方式时,如果没有传递参数,那么事件方法会默认传一个事件对象参数。
    setName(e){
    this.name = e.target.value
    },
    },
    })
  2. 条件渲染和列表渲染
    <div id="app">

    <button v-on:click="isShow=!isShow">显示/隐藏</button>

    <div class="box" v-if="isShow">
    v-if
    </div>

    <div class="box" v-show="isShow">v-show</div>


    <h2 v-if="score>=90">优秀</h2>
    <h2 v-else-if="score>=80">良好</h2>
    <h2 v-else-if="score>=70">中等</h2>
    <h2 v-else-if="score>=60">合格</h2>
    <h2 v-else>差</h2>


    <ul>

    <li v-for="(item,index) in goodses" v-bind:key="index">
    {{item.id}}---{{item.name}}---{{item.price}}
    <button v-on:click="delGoods(index)">删除</button>
    </li>
    </ul>
    </div>
    new Vue({
    el:'#app',
    data:{
    // 该属性,用于表示是否显示
    isShow:true,
    // 定义一个成绩
    score:88,
    // 定义一个数组
    goodses:[
    {
    id:1001,
    name:'乐事薯片',
    price:'8元'
    },
    {
    id:1002,
    name:'百事可乐',
    price:'3元'
    },
    {
    id:1003,
    name:'元祖月饼',
    price:'10元'
    },
    {
    id:1004,
    name:'德芙巧克力',
    price:'29元'
    }
    ]
    },
    methods: {
    // 删除商品的方法,将商品的下标通过方法传进来
    delGoods(index){
    if(confirm('是否确定删除')){
    // 再根据数组的下标删除对应的数据
    this.goodses.splice(index,1)
    }
    }
    },
    })
    二、生命周期
  3. 小练习
    <div id="app">
    <button @click="showEdit=true">添加学生</button>

    <table>
    <thead>
    <tr>
    <th>学号</th>
    <th>姓名</th>
    <th>年龄</th>
    <th>性别</th>
    <th>操作</th>
    </tr>
    </thead>
    <tbody>
    <tr v-for="(item,index) in students" :key="index">
    <td>{{item.no}}</td>
    <td>{{item.name}}</td>
    <td>{{item.age}}</td>
    <td>{{item.sex}}</td>
    <td>
    <button @click="getOne(index)">修改</button>
    <button @click="del(index)">删除</button>
    </td>
    </tr>
    </tbody>
    </table>

    <div class="edit" v-show="showEdit">

    <div class="close" @click="close">X</div>
    <div class="item">
    <label>学号:</label>
    <input type="text" v-model="no">
    </div>
    <div class="item">
    <label>姓名:</label>
    <input type="text" v-model="name">
    </div>
    <div class="item">
    <label>年龄:</label>
    <input type="text" v-model="age">
    </div>
    <div class="item">
    <label>性别:</label>
    <input type="text" v-model="sex">
    </div>
    <div class="item">
    <button @click="add" v-if="updateIndex===-1">添加</button>
    <button @click="update" v-else>修改</button>
    <button @click="clear">取消</button>
    </div>
    </div>
    </div>
    new Vue({
    // 指定该Vue实例工作的容器
    el:'#app',
    // 定义当前Vue实例管理的数据
    data:{
    // 定义一个学生数组
    students:[
    {
    no:'1001',
    name:'张三',
    age:20,
    sex:'男'
    },
    {
    no:'1002',
    name:'李四',
    age:22,
    sex:'女'
    },
    {
    no:'1003',
    name:'王五',
    age:24,
    sex:'男'
    },
    {
    no:'1004',
    name:'赵六',
    age:18,
    sex:'女'
    }
    ],
    // 是否显示编辑窗口
    showEdit:false,
    // 定义一个学生对象的四个属性
    no:'',
    name:'',
    age:'',
    sex:'',
    // 定义一个下标,用于表示修改的学生在数组中的位置
    updateIndex:-1
    },
    // 定义当前Vue实例管理的方法
    methods: {
    // 添加方法
    add(){
    // 创建一个学生对象
    let stu = {
    no:this.no,
    name:this.name,
    age:this.age,
    sex:this.sex
    }
    // 将学生对象添加到学生数组中
    this.students.push(stu)
    // 调用清空数据的方法
    this.clear()
    },
    // 清空表单数据的方法
    clear(){
    this.no = ''
    this.name = ''
    this.age = ''
    this.sex = ''
    },
    // 关闭编辑窗口的方法
    close(){
    // 隐藏编辑窗口
    this.showEdit = false
    // 编辑窗口关闭时,重新将修改索引改成-1
    this.updateIndex = -1
    // 清空表单数据
    this.clear()
    },
    // 删除方法
    del(index){
    if(confirm('确定删除吗?')){
    this.students.splice(index,1)
    }
    },
    // 根据下标从数组中获取对应的学生信息
    getOne(index){
    // 获取学生对象在数组中对应的下标
    this.updateIndex = index
    // 显示编辑窗口
    this.showEdit = true
    // 获取学生
    let stu = this.students[index]
    // 在编辑窗口中显示该学生信息
    this.no = stu.no
    this.name = stu.name
    this.age = stu.age
    this.sex = stu.sex
    },
    // 修改方法
    update(){
    // 修改数组中,指定位置学生的信息
    let stu = this.students[this.updateIndex]
    stu.no = this.no
    stu.name = this.name
    stu.age = this.age
    stu.sex = this.sex
    }
    },
    })
  4. Vue的生命周期
    <div id="app">
    <button @click="name+='*';age+=1">修改数据</button>
    <button @click="over">销毁Vue实例</button>
    <h2>{{name}}</h2>
    <h2>{{age}}</h2>
    </div>
    let vm = new Vue({
    // el选项可以通过mount代替 // el:'#app', // 如果有template选项,Vue会将template作为模板进行渲染,并将渲染之后的内容挂载到指定的容器中 // 如果没有template选项,Vue就会将el里面的所有内容当做模板来渲染,并将渲染之后的内容挂载到指定的容器中 /* template:` <div> <p>{{name}}</p> <p>{{age}}</p> </div>`, */ data:{ name:'张三', age:20 }, methods: { over(){ //destroy()方法,用于销毁当前Vue实例
    // 注意:销毁当前Vue实例,不是删除这个对象,而且这个对象再也不具备响应式页面的能力了。
    this.destroy() } }, // 数据初始化之前 beforeCreate() { console.log('beforeCreate:',this.name,this.age); }, // 数据初始化完成 created() { console.log('created:',this.name,this.age); }, // 页面挂载之前,此时页面是模板 beforeMount() { // 通过el返回Vue实例使用的根 DOM 元素
    console.log(this.el); console.log('beforeMount'); }, // 页面挂载完成,此时页面已经渲染完成 mounted() { console.log(this.el);
    console.log('mounted');
    },
    // 数据更新之前
    beforeUpdate() {
    // 在这个阶段,数据已经发生了变化,但是页面还没有重新渲染
    console.log('beforeUpdate',this.name,this.age);
    },
    // 数据更新完成
    updated() {
    // 在这个阶段,页面会重新渲染
    console.log('updated',this.name,this.age);
    },
    // 销毁之前
    beforeDestroy() {
    // 我们通常会在这个生命周期函数中做一些收尾的工作
    // 比如:停掉开启的定时器,初始化一些数据等等。
    console.log('beforeDestroy');
    },
    // 销毁完成
    destroyed() {
    console.log('destroyed');
    console.log(this);
    },
    })

setTimeout(() => {
// 通过mount方法,给vm指定一个容器 // 这种写法的好处是,可以控制何时挂载页面 vm.mount('#app')
}, 1000);

  1. 轮播图
    <div id="app">

    <img :src="imgs[index]">
    <ul>
    <li v-for="(item,i) in imgs" :class="i===index?'active':''"></li>
    </ul>
    </div>
    new Vue({
    el:'#app',
    data:{
    // 定义轮播图图片数组
    imgs:["http://p1.music.126.net/lrd-pX9Azcv2mP8-YnQ3JA==/109951166362109457.jpg?imageView&quality=89",
    "http://p1.music.126.net/RXFG298sUeqJlpIGoZvB0Q==/109951166362198241.jpg?imageView&quality=89",
    "http://p1.music.126.net/GHcB-WR3T3UhEO5msHXOXg==/109951166362228128.jpg?imageView&quality=89",
    "http://p1.music.126.net/Wd08w_8bojR4DWyK7EEkeQ==/109951166362223634.jpg?imageView&quality=89",
    "http://p1.music.126.net/y3OQm6kP7nPqRcCBkPRSdQ==/109951166362444141.jpg?imageView&quality=89"],
    // 定义索引
    index:0,
    // 定义一个定时器变量
    timer:null
    },
    methods: {
    // 销毁Vue实例的方法
    destroy(){
    // 当前Vue实例一旦销毁,就不再具体响应页面的能力了
    this.$destroy()
    }
    },
    // 在这个阶段,页面已经好了
    mounted() {
    // 开启一个定时器
    this.timer = setInterval(() => {
    if(++this.index>=this.imgs.length) this.index = 0
    }, 3000);
    },
    // 在这个阶段,Vue的实例即将销毁
    beforeDestroy() {
    // 清除定时器
    clearInterval(this.timer)
    },
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • 1. 初始化vue 第一步:给Vue准备一个容器: <!-- 在页面中,通过插值表达式可以直接使用Vue管理的数据...
    绯泉阅读 211评论 0 1
  • 1.ES6语法 1.1 let与const let是声明块级变量,作用域某个代码块中,离开代码块失效! 报错:i ...
    hanfy阅读 191评论 0 0
  • v-on:指令用于绑定事件 v-on:click指令用于绑定点击事件 给对象添加属性 方式1:obj.name =...
    伴_5aa1阅读 226评论 0 1
  • Vue.js入门教程 参考文献 Vue-Cli webpack打包入门:http://www.cnblogs.co...
    采香行处蹙连钱阅读 1,431评论 2 3
  • 大前端进阶 前端三剑客:HTML+CSS+JS 前端框架:jQuery、BootStrap、Vue vue的思想是...
    MaxWen阅读 644评论 0 1