Vue 教程第四篇—— Vue 实例化时基本属性

实例元素 el

实例元素指的是 Vue 实例化时编译的容器元素,或者说是 Vue 作用的元素容器

    <div id="app"></div>
    var vm = new Vue({el: '#app'})

也可以为实例元素指定其它选择器

    <div class="app"></div>
    var vm = new Vue({el: '.app'})

可以有多个实例元素

    <div id="app1"></div><div id="app2"></div>
    var vm = new Vue({el: '#app1'})var vm = new Vue({el: '#app2'})    

如果有多个相同的实例元素则只有第一个起效

    <div id="app"></div><!--这个只当普通 html 输出,不会被 Vue 编译--><div id="app"></div>
    var vm = new Vue({el: '#app'})

也可以在实例化的时候不指定实例元素,后面用 $mount() 手动进行挂载

    <div id="app"></div>
    var vm = new Vue({//option})vm.$mount("#app");

可以通过实例获取实例元素

    var vm = new Vue({el: '#app'})console.log(vm.$el)

数据对象 data

在 MVVM 模式中充当着 M(Model) 数据模型层,更多的体现于将 M 层映射到 V 层

    <div id="app"><!--结果为:文本--><span>{{key1}}</span><!--结果为:11--><span>{{key2 + key3}}</span><!--结果为:key4_1--><span>{{key4.key4_1}}</span><!--结果为:{"key5_1": "key5_1"}--><span>{{JSON.stringify(key5[0])}}</span></div>
    var array = [{key5_1: "key5_1"}];var vm = new Vue({el: '#app',data: {key1: '文本',key2: 1,key3: 10,key4: {key4_1: 'key4_1'},key5: array}}

可以通过实例获取数据对象

    var vm = new Vue({el: '#app',data: {}})console.log(vm.$data)

事件处理器 methods

元素可以通过 v-on:事件 || @事件 进行绑定事件,事件中的 this 默认指向实例 vm

    <div id="app"><input type="button" @click="count += 1" value="监听事件"><span>{{count}}</span></div>
    var vm = new Vue({el: '#app',data: {count: 0}})

上面的情况仅适用于很简单的处理,复杂的处理可以需要单独处理上面的情况仅适用于很简单的处理,复杂的处理可以需要单独处理

    <div id="app"><input type="button" value="确认" @click="counter"/><p>确认按钮被点击了 {{ counter }} 次。</p></div>
    var vm = new Vue({el: '#app',data: {count: 0},methods: {counter: function(){this.count += 1;}}})

在 js 的事件中默认会有个 event 对象,Vue 在事件上对 event 对象进行继承二次封装,改名为 $event,在事件当中默认传过去

    <div id="app"><input type="button" @click="eventer" count="1" value="event 对象"><span>{{count}}</span></div>
    var vm = new Vue({el: '#app',data: {count: 0},methods: {eventer: function(event){var _count = event.target.getAttribute('count') * 1;this.count += _count;event.target.setAttribute('count', _count);}}})

在事件中很多情况下要传参数,Vue 也可以在事件中传参数

    <div id="app"><input type="button" @click="parameter(10, $event)" value="事件传参数"><span>{{count}}</span></div>
    var vm = new Vue({el: '#app',data: {count: 0},methods: {parameter: function(n, event){this.count += n;event.target.setAttribute('disabled', true);}}})

事件效果预览

计算属性 computed

computed 主要是针对 data 的属性进行操作,this 的指针默认指向实例 vm

    <p>{{reversedMessage}}</p>
    data: {message: 'ABC'},computed: {reversedMessage: function(){return this.message.split('').reverse().join('')}}

渲染结果为

    <p>CBA</p>

在 computed 的属性中默认有两个属性,一个是 get,我们称之为 getter,另一个是 set,我们称之为 setter,所以也可以这样写:

    data: {message: 'ABC'},computed: {reversedMessage: {get: function(){return this.message.split('').reverse().join('')}}}

当我们在 V 层调用 {{reversedMessage}} 的时候会自动触发 reversedMessage.get()

setter 的逻辑也是一样,当改变对应的属性时,会自动触发 set 方法

    <div id="app"><!--调用了 fullName.get()--><p>{{fullName}}</p><input type="text"  v-model="newName"><!--changeName 事件改变了 fullName 的值,所以会自动触发 fullName.set()--><input type="button" value="changeName" @click="changeName"></div>
    var vm = new Vue({el: '#app',data: {firstName:'DK',lastName: 'Lan',newName: ''},computed: {fullName:{get: function(){return this.firstName + '.' + this.lastName},set: function(newValue){this.firstName = newValue}}},methods: {changeName: function(){this.fullName = this.newName;}}})

Vue 在 getter 上面作了基于对应属性的依赖缓存,也就是说多次调用同一个属性,get 只会执行一次。而事件在每次触发时都会被调用,当然在改变该属性值的时候会再次被调用

    <div id="app"><!--fullName.get 只被调用一次--><p>{{fullName}}</p><p>{{fullName}}</p><p>{{fullName}}</p><!--每次点击都会调用 changeName--><input type="button" value="changeName" @click="changeName('Vue')"></div>
    var vm = new Vue({el: '#app',data: {firstName:'DK',lastName: 'Lan',newName: ''},computed: {fullName:{get: function(){return this.firstName + '.' + this.lastName},set: function(newValue){this.firstName = newValue}}},methods: {changeName: function(txt){this.newName = txt;//如果在这里改变 this.fullName 的值,则会再次自动触发对应的 getter}}})

计算属性效果预览

监听器 watch

Vue 提供了对单个属性的监听器,当该属性发生改变的时候,自动触发,此项使用不当会影响性能,所以慎用。

    <input type="text" v-model="a"><p>旧值:{{aOldVal}}</p><p>新值:{{aNewVal}}</p>    
    {data: {a: 1},watch: {a: function (newVal, oldVal) {//自动触发此方法console.log('new: %s, old: %s', newVal, oldVal)},}    }

也可以把方法放到 data 对象中

    {data: {a: 1,changeA: function (newVal, oldVal) {//自动触发此方法console.log('new: %s, old: %s', newVal, oldVal)}},watch: {a: 'changeA'}    }

watch 与 compute 区别:

  1. computed 创建新的属性, watch 监听 data 已有的属性
  2. compute 会产生依赖缓存
  3. 当 watch 监听 computed 时,watch 在这种情况下无效,仅会触发 computed.setter
    {computed: {a: {get: function(){return '';},set: function(newVal){//会触发此项console.log('set val %s', newVal);}}                 },watch: {a: function(){//不会被触发console.log('watch');}}    }

监听器效果预览

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/451961.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu将在明年推出平板及手机系统

4月26日下午消息&#xff0c;知名Linux厂商Canonical今天正式发布Ubuntu 12.04版开源操作系统。Ubuntu中国首席代表于立强透露&#xff0c;针对平板电脑的Ubuntu操作系统将在明年推出。 Ubuntu 12.04版开源操作系统发布 Ubuntu操作系统是一款开源操作系统&#xff0c;主要与OE…

scrapy框架异常--no more duplicates will be shown (see DUPEFILTER_DEBUG to show all duplicates)

解决方法&#xff1a; https://blog.csdn.net/qq_40176258/article/details/86527568 https://blog.csdn.net/weixin_39946931/article/details/88390797 谢谢博主分享&#xff01;

【BZOJ3590】[Snoi2013]Quare 状压DP

题解&#xff1a; 一道比较水的题 但这个测试数据极弱我也不知道我的代码正确性是不是有保证 构成一个边双联通 可以由两个有一个公共点的边双联通或者一个边双加一条链构成 所以我们需要要预处理出所有环 令f[i][j][k]表示起点为i&#xff0c;终点为j&#xff0c;经过点的状态…

java swing简介

UI 组件简介 在开始学习 Swing 之前&#xff0c;必须回答针对真正初学者的一个问题&#xff1a;什么是 UI&#xff1f;初学者的答案是“用户界面”。但是因为本教程的目标是要保证您不再只是个初学者&#xff0c;所以我们需要比这个定义更高级的定义。 所以&#xff0c;我再次…

定时任务 cron 表达式详解

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 &#xff08;Spring定时任务的几种实现&#xff1a;见博客另一页&#xff1a;http://blog.csdn.net/jiangyu1013/article/details/54405…

Android Studio 超级简单的打包生成apk

为什么要打包&#xff1a; apk文件就是一个包&#xff0c;打包就是要生成apk文件&#xff0c;有了apk别人才能安装使用。打包分debug版和release包&#xff0c;通常所说的打包指生成release版的apk&#xff0c;release版的apk会比debug版的小&#xff0c;release版的还会进行混…

推荐16款最棒的Visual Studio插件

Visual Studio是微软公司推出的开发环境&#xff0c;Visual Studio可以用来创建Windows平台下的Windows应用程序和网络应用程序&#xff0c;也可以用来创建网络服务、智能设备应用程序和Office插件。 本文介绍16款最棒的Visual Studio扩展&#xff1a; 1. DevColor Extension…

网络爬虫--22.【CrawlSpider实战】实现微信小程序社区爬虫

文章目录一. CrawlSpider二. CrawlSpider案例1. 目录结构2. wxapp_spider.py3. items.py4. pipelines.py5. settings.py6. start.py三. 重点总结一. CrawlSpider 现实情况下&#xff0c;我们需要对满足某个特定条件的url进行爬取&#xff0c;这时候就可以通过CrawlSpider完成。…

可以生成自动文档的注释

使用/**和*/可以用来自动的生成文档。 这种注释以/**开头&#xff0c;以*/结尾

怎么安装Scrapy框架以及安装时出现的一系列错误(win7 64位 python3 pycharm)

因为要学习爬虫&#xff0c;就打算安装Scrapy框架&#xff0c;以下是我安装该模块的步骤&#xff0c;适合于刚入门的小白&#xff1a; 一、打开pycharm&#xff0c;依次点击File---->setting---->Project----->Project Interpreter&#xff0c;打开后&#xff0c;可以…

illegal to have multiple occurrences of contentType with different values 解决

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 在网上查到说是&#xff1a;“包含页面与被包含页面的page指令里面的contentType不一致&#xff0c;仔细检查两个文件第一行的 page....…

xpath-helper: 谷歌浏览器安装xpath helper 插件

1.下载文件xpath-helper.crx xpath链接&#xff1a;https://pan.baidu.com/s/1dFgzBSd 密码&#xff1a;zwvb&#xff0c;感谢这位网友&#xff0c;我从这拿到了 2.在Google浏览器里边找到这个“扩展程序”选项菜单即可。 3.然后就会进入到扩展插件的界面了,把下载好的离线插件…

网络爬虫--23.动态网页数据抓取

文章目录一. Ajax二. 获取Ajax数据的方式三. seleniumchromedriver获取动态数据四. selenium基本操作一. Ajax 二. 获取Ajax数据的方式 三. seleniumchromedriver获取动态数据 selenium文档&#xff1a;https://selenium-python.readthedocs.io/installation.html 四. sele…

视音频编解码技术及其实现

核心提示&#xff1a;一、视音频编码国际标准化组织及其压缩标准介绍 国际上有两个负责视音频编码的标准化组织&#xff0c;一个是VCEG&#xff08;VideocodeExpertGroup&#xff09;&#xff0c;是国际电信联合会下的视频编码专家组&#xff0c;一个是MPEG&#xff08;MotionP…

什么是NaN

NaN&#xff0c;是Not a Number的缩写。NaN 用于处理计算中出现的错误情况&#xff0c;比如 0.0 除以 0.0 或者求负数的平方根。由上面的表中可以看出&#xff0c;对于单精度浮点数&#xff0c;NaN 表示为指数为 emax 1 128&#xff08;指数域全为 1&#xff09;&#xff0c;…

排序系列【比较排序系列之】直接插入排序

最近在和小伙伴们一起研究排序&#xff0c;排序分好多总&#xff0c;后期会做整体总结&#xff0c;本篇则主要对插入排序进行一个整理。 插入排序&#xff08;insert sorting&#xff09;的算法思想十分简单&#xff0c;就是对待排序的记录逐个进行处理&#xff0c;每个新纪录…

Mysql 无法插入中文,中文乱码解决

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 在计算机中搜索 my.ini文件 找到后打开 &#xff0c;并找到这2行作 如下设置 &#xff1a; default-character-setutf8character-se…

gcc g++安装

2019独角兽企业重金招聘Python工程师标准>>> 安装之前要卸载掉老版本的gcc、g sudo apt-get remove gccgcc-xx #可能有多个版本&#xff0c;都要删掉 sudo apt-get remove g sudo apt-get install gcc 安装g编译器&#xff0c;可以通过命令 sudo apt-get installb…

网络爬虫--24.【selenium实战】实现拉勾网爬虫之--分析接口获取数据

文章目录一. 思路概述二. 分析数据接口三. 详细代码一. 思路概述 1.拉勾网采用Ajax技术&#xff0c;加载网页时会向后端发送Ajax异步请求&#xff0c;因此首先找到数据接口&#xff1b; 2.后端会返回json的数据&#xff0c;分析数据&#xff0c;找到单个招聘对应的positionId…