接下来我们继续学习一天带你入门到放弃系列vue.js(二),如有问题请留言讨论!

v-if

index.html


<div id="app">
<p v-if="user=='admin' && chmod == 777">欢迎管理员</p>
<p v-else-if="user != 'admin' && user !='' ">欢迎用户登录</p>
<p v-else>欢迎游客登录</p>
</div>

可以使用不同的数据进行判断呈递不同的显示效果

计算属性

可以调用计算属性的方法,在vue中调取comouted中定义

看一下简单个人计算存款的html

<table>
<thead>
<th>项目名称</th>
<th>资产分配情况(单位:&yen;)</th>
</thead>
<tbody>
<tr>
<td>支付宝</td>
<td><input type="text" v-model.number="alipay"></td>
</tr>
<tr>
<td>京东金融</td>
<td><input type="text" v-model.number="jd"></td>
</tr>
<tr>
<td>银行卡</td>
<td><input type="text" v-model.number="yhk"></td>
</tr>
<tr>
<td>定期</td>
<td><input type="text" v-model.number="dq"></td>
</tr>
<tr>
<td>基金</td>
<td><input type="text" v-model.number="jj"></td>
</tr>
<!--使用内置的计算方式:computed-->
<tr>
<td>总存款</td>
<td>{{sum}}</td>
</tr>
<tr>
<td>资产均值</td>
<td>{{average}}</td>
</tr>
</tbody>
</table>

main.js中data数据

  

data: {
alipay:1154,
jj:3552,
dq:24000,
jd:3580,
yhk:36871
}

想必我们大家都会使用传统的方式进行data中变量进行如下假发计算获取


        <!--普通方式计算-->
<!--<tr>-->
<!--<td>总存款</td>-->
<!--<td>{{alipay+jd+yhk+dq+jj}}</td>-->
<!--</tr>-->

至此在vue中提供了计算属性,computed,在main.js指定computed对象中指定计算

  

computed:{
sum:function (){
return this.alipay+this.jj+this.dq+this.jd+this.yhk;
},
那么前台直接去调取computed中的方法
        <tr>
<td>总存款</td>
<td>{{sum}}</td>
</tr>
<tr>
<td>资产均值</td>
<td>{{average}}</td>
</tr>

在前台中我们使用了if-model绑定了data的数据可以根据自行的改变,视图层,数据层则随之改变,但是input的数字变为String类型,无法达到计算的效果!前面我们说过使用if-model.number可以返回数值类型!此时可以达到计算效果

自定义组件

组件:具有特定功能的标签,我们可以去指定,这样的标签可以进行大量的使用!

分类:全局组件和局部组件

区别:全局组件在所有范围通用,局部组件只在特点的element元素中生效!

全局组件

定义方式

  

Vue.component('btn',{
data:function (){
return{
count:0
}
},
template:`<button @click="count++">此按钮被你狠点了{{count}}下</button>`
})

此时这个btn组件(全局组件,定义完成,但是使用还需要进一步建立Vue实例)

  

new Vue({
el:"#app"
})

前台调用组件


<div id="app">
<btn></btn>
</div>

简单介绍下这个组件,btn是组件名称,在定义组件的时候捆绑的data必须是一个函数(Function),而且这个函数必须拥有return,所调取的数据是通过return返回的对象!

template是这个组件构建的模板!

局部组件

通过名字很容易联想到这个组件的使用范围具有限制性,

定义方式

  

st1=new Vue({
el: "#st1",
components: {
alert: {
data:function (){
return{
str:"113354",
rea:111
}
},
template: `<button @click="onAlert">弹死你!!!</button>`,
methods: {
onAlert: function () {
alert(this.rea)
}
}
}
}
})

局部组件在新建Vue实例的时候,新建一个components对象指定出组件模板,方法(methods),以及数据(data),此时组件的应用范围只有在新建实例的el指定的范围,否则Vue则报错!

组件配置

全部组件和局部组件大家通过上述的实例差不多了解了,进一步了解一下咱们自己写的组件还有那些配置项,这些配置项的功能都有哪些!

一般常用的三个:

1.template(模板,必选)

2.data数据

3.methods定义的方法

组件通讯

前面我们简单的了解了组件的定义,以及配置!这里我们看一下组件直接的数据传递也叫组件通讯如何实现!

分类:

1.父子传递(父传子)

2.子父传递(子传父)

3.同级传递(同一辈分组件)

父子传递

我们定义一个alert组件用于弹出信息提示框

首先我们看下前台(msg为弹出的提示信息)


<alert msg="你好!!!"></alert>

main.js

  

Vue.component('alert',{
template:`<button @click="onClick">点我</button>`,
props:['msg'],
methods:{
onClick:function (){
alert(this.msg)
}
}
})

在组件的中新建一个props数组,这里是msg于调取时候的消息msg名称保持一致,此时这个数据存储在props中,我们需要点按钮去改变这个内容,在组件的methos方法中定义alert(this.msg),this只带这个组件(component中的msg),数据传递成功!

子父传递

我们有个需求,在一个父级组件中包含一个子组件,而改变了子组件的状态后,父级组件得到不同的状态反馈!此时这个子组件的状态变量如何传递呢?接下来看一下这个传递实现方式!

首先定义一下父组件

  

Vue.component('parent',{
template: `
<div>
<son @show_ye="show_ye"></son>
<p v-if="show">余额:¥183.25</p> </div>
`
})

新建子组件

  

//子组件
Vue.component('son',{
template:`<button @click="onClick">我的余额</button>`,
methods:{
onClick:function(){
this.$emit('show_ye',{
a:1,
b:2
})
}
}
})

新建的父组件(<parent></parent>)子组件(<son></son>),子组件是一个按钮,点击后会执行click事件,

此时需要在父组件中的子组件(<son></son>)上捆绑一个事件监控v-on:show_ye,绑定这个事件,

而在子组件进行监听这个show_ye事件,在methods中的this.$emit是监听了这个事件,{a:1,b:2}是成功监听后传出的数据,在父组件中有个是否显示余额的变量show,在父组件中默认是false,父组件的methos中要有这个show_ye方法,成功监听到这个事件后,子组件则传递到父组件,并将data的数据发送给父组件

完整的组件代码(main.js)

  

//父组件
Vue.component('parent',{
template: `
<div>
<son @show_ye="show_ye"></son>
<p v-if="show">余额:¥183.25</p> </div>
`,
data:function(){
return{
show:false
}
},
methods:{
show_ye:function(data){
this.show=true
console.log(data)
}
}
}) //子组件
Vue.component('son',{
template:`<button @click="onClick">我的余额</button>`,
methods:{
onClick:function(){
this.$emit('show_ye',{
a:1,
b:2
})
}
}
})

在子组件成功监听到这个show_ye后,父组件的methods方法指定这个使用data参数则就能获取到子组件的data!

同级传递

前台2个组件

<div id="app">
<interview>aa</interview>
<worker>bb</worker>
</div>

interview和worker两个同级组件,boos中指定了input框,并使用v-model绑定了这个变量,可以去在数据层改变这个数,而在worker中可以正常显示这个变量的数值

组件的建立

  

<script type="text/javascript">

    //调度器
var Event = new Vue(); //面试
Vue.component('interview', {
//定义组件模板内容
template: `
<div>我今天面试拿到的税前工资是:
<input v-model="pre_tax_money" type="number" @blur="onChangeMethod" >
</div>`,
//定义组件的方法
methods: {
onChangeMethod: function () {
//$emit负责对事件的监听,类似jquery的trigger
Event.$emit("onChangeMethod", this.pre_tax_money);
}
},
data: function () {
return {
pre_tax_money: "",//税前工资
}
}
}); //面试成功,工作
Vue.component('worker', {
//定义组件模板内容
template: `
<div>我今天面试拿到的税后工资是:
{{after_tax_money}}
</div>`,
data: function () {
return {
after_tax_money: "",//税后工资
}
},
//钩子(类似小程序声明周期,页面渲染完毕后)
mounted: function () {
var _this = this;
//监控当前事件
Event.$on("onChangeMethod", function (pre_tax_money) {
console.log("pre_tax_money=" + pre_tax_money);
_this.after_tax_money = pre_tax_money * 0.9;
})
} }); new Vue({el: "#app"}); </script>
 

在boos这个组件捆绑一个数据pre_tax_money,当执行这个onChange后,进行监听这个事件,把这个数值传给调度器(Event),此时就是只要父组件中onChange执行后,则被调度器监听!数值被传入Event对象中

在被需要获取这个数据的组件中,首先定义一个数据data,return返回的名称于原数据不同,此时我们叫after_tax_money,还需要定义一个类似小程序的生命周期的东西,这里Vue官方称之为钩子,在这个组件中新建的对象mounted:中指定,在这个钩子中我们用调度器绑定刚才监听的那个事件onChange,回调函数的参数为data,就是刚才传入的data,但是此时使用this,这个this指定为Event对象,而不是component,在Event.$on之外我们首先要获取到这个component,使用that代替,然后进入钩子(mounted)赋值给component的data数据层就可以了!

原数据的methos方法

  

        //定义组件的方法
methods: {
onChangeMethod: function () {
//$emit负责对事件的监听,类似jquery的trigger
Event.$emit("onChangeMethod", this.pre_tax_money);
}
},

获取数据的钩子代码(mounted)

  

        //钩子(类似小程序声明周期,页面渲染完毕后)
mounted: function () {
var _this = this;
//监控当前事件
Event.$on("onChangeMethod", function (pre_tax_money) {
console.log("pre_tax_money=" + pre_tax_money);
_this.after_tax_money = pre_tax_money * 0.9;
})
}

首先在钩子内指定获取到这个component!

完整的代码在组件建立的就是了!

转自 十月梦想博客 。
原文地址《一天带你入门到放弃vue.js(一)

相关文章:

一天带你入门到放弃vue.js(一)

一天带你入门到放弃vue.js(二)

一天带你入门到放弃vue.js(三)

一天带你入门到放弃vue.js(二)的更多相关文章

  1. 一天带你入门到放弃vue.js(三)

    自定义指令 在上面学习了自定义组件接下来看一下自定义指令 自己新建的标签赋予特殊功能的是组件,而指定是在标签上使用类似于属性,以v-name开头,v-on,v-if...是系统指令! v-是表示这是v ...

  2. 一天带你入门到放弃vue.js(一)

    写在前面的话! 每个新的框架入手都会进行一些列的扯犊子!这里不多说那么多!简简单单说一下vue吧! Vue.js是目前三大框架(angular,vue,react)之一,是渐进式js框架,据说是摒弃了 ...

  3. 5分钟带你入门vuex(vue状态管理)

    如果你之前使用过vue.js,你一定知道在vue中各个组件之间传值的痛苦,在vue中我们可以使用vuex来保存我们需要管理的状态值,值一旦被修改,所有引用该值的地方就会自动更新,那么接下来我们就来学习 ...

  4. vue.js 二维码生成组件

    安装 通过NPM安装 npm install vue-qart --save 插件应用 将vue-qart引入你的应用 import VueQArt from 'vue-qart' new Vue({ ...

  5. Python爬虫从入门到放弃(十二)之 Scrapy框架的架构和原理

    这一篇文章主要是为了对scrapy框架的工作流程以及各个组件功能的介绍 Scrapy目前已经可以很好的在python3上运行Scrapy使用了Twisted作为框架,Twisted有些特殊的地方是它是 ...

  6. 【JavaScript从入门到放弃】JS基础-01

    作为一个前端开发人员,JS是我们行走江湖吃饭的家伙.基本上一个前端人员能值多少大洋,就看JS了.虽然各种框架层出不穷,但是归根结底学好原生JS才是硬道理. 学习任何新东西其实都遵循 10000 小时成 ...

  7. vue.js 二 路由懒加载

    当项目小的时候,我没考虑要去找这个得解决方案,也幸好现在几乎能迁移的项目都整合在了一个vue的项目里面 才发现编译后的vendor.js变得异常的大,而且几乎在项目每一个页面都需要加载这一个js,项目 ...

  8. 《vue.js2.0从入门到放弃》学习之路

    原文地址: Vue.js2.0从入门到放弃---入门实例(一):http://blog.csdn.net/u013182762/article/details/53021374 Vue.js2.0从入 ...

  9. Vue.js入门

    之前一直用的是jQuery,jQuery手动操作DOM导致性能不够好,因为DOM修改导致的页面重绘.重新排版!重新排版是用户阻塞的操作,同时,如果频繁重排,CPU使用率也会猛涨! Vue.js是数据驱 ...

随机推荐

  1. [Qualcomm]A Detailed History of Qualcomm 高通的前世今生

    https://www.semiwiki.com/forum/content/7353-detailed-history-qualcomm.html

  2. LoadRunner【第四篇】参数化

    参数化的定义及使用场景 定义:将脚本中的特定值用变量替代,该变量值是变化的(注意:这个值是我们自己创建的,不是服务器返回的). 使用参数化: 1.业务考虑,不允许相同信息 2.真实模拟不同用户 3.真 ...

  3. LOJ#2339 通道

    题意:给你三棵树,求所有点对在三棵树上的距离和中的最大值. 解:首先有个暴力,然后还有个迭代乱搞,可以得到61分... namespace bf { inline void solve() { ; i ...

  4. boost库在windows上的安装

    下载源码boost_1_70_0.zip 1.cmd进入boost源码包,运行bootstrap.bat生成bjam.exe 2.运行bjam.exe搞定 在visual studio配置 1. 项目 ...

  5. Qt调用自己编译的libglog.a出现问题

    我确定依据正确导入库后,依旧出现未定义的引用. undefined reference to _imp___ZN6google17InitGoogleLoggingEPKc 尝试过重新编译,调整编译参 ...

  6. openJDK之如何下载各个版本的openJDK源码

    如果我们需要阅读openJDK的源码,那么需要下载,那么该去哪下载呢? 现在JDK已经发展到版本10了,11已经处于计划中,如果需要特定版本的openJDK,它们的下载链接在哪呢? 1.openJDK ...

  7. DirectX11 With Windows SDK--01 DirectX11初始化

    前言 由于个人觉得龙书里面第4章提供的Direct3D 初始化项目封装得比较好,而且DirectX SDK Samples里面的初始化程序过于精简,不适合后续使用,故选择了以Init Direct3D ...

  8. 前端面试题整理—jQuery篇

    1.为什么使用jquery,他有哪些好处? 1)轻量级.代码简洁 2)强大的选择器,出色的DOM操作封装 3)有可靠的事件处理机制 4)浏览器兼容性好 5)支持链式操作 6)支持丰富的插件 2.jqu ...

  9. densenet 中的shortcut connection

    DenseNet  在FCN 网络中考虑加入skip connection,在resnet 中加入identity 映射,这些 shortcut connection等结构能够得到更好的检测效果,在d ...

  10. 学习熟悉箭头函数, 类, 模板字面量, let和const声明

    箭头函数:https://blog.csdn.net/qq_30100043/article/details/53396517 类:https://blog.csdn.net/pcaxb/articl ...