绑定样式&计算属性&侦听器&过滤器

绑定样式

:class样式绑定

:class可以绑定一个对象,对象的属性名是类选择器的名称,属性值返回true,表示添加该选择器。
:class 三元表达式判断 :class="activeindex === index? 'active' : '' "

<div id="app">
  <ul class="list">
    <li v-for="(item, index) in citys" :key="index" :class="activeindex===index?'active':'' " @click="activeindex=index" >{{item}}</li>
  </ul>
</div>

:class 对象格式去判断:class="{active : index === activeindex }"

<ul class="list">
  <li v-for="(item, index) in citys" :key="index" :class="{active:index===activeindex}" @click="activeindex=index" >{{item}}</li>
</ul>

每个按钮绑定一个事件, :class返回的时true 才能够把样式添加进去

        <button @click="bgcolor=true">修改背景色</button>
        <button @click="fzcolor=true">修改文本色</button>
        <button @click="borcolor=true">添加边框</button>
                                //class选择器:变量名(布尔值类型)
        <div class="box1" :class="{bgcolor:bgcolor,fzcolor:fzcolor,borcolor:borcolor}" >
            字体阿斯顿啊阿斯顿阿斯顿
        </div>
          //还可以用数组的形式判断,每一项用三元表达式来判断  (变量名:class选择器)
        <div class="box1" :class="[bgcolor?'bgcolor':'',fzcolor?'fzcolor':'',borcolor?'borcolor':'']" >
            字体阿斯顿啊阿斯顿阿斯顿
        </div>

:style样式绑定

对象的属性名称是css样式的名称(要使用小驼峰命名法),属性值是具体的样式值(例:"red")

<div class="box1" :style="{backgroundColor:bg,color:co}">
            字体阿斯顿啊阿斯顿阿斯顿
            <input type="text" v-model="bg">
            <input type="text" v-model="co">
</div>

class 样式

  .bgcolor{
        background-color: orangered;
    }
    .fzcolor{
        color: white;
    }
    .borcolor{
        border: 1px solid blue;
    }
 new Vue({
            el:'#app',
            data: {
                citys:['北京','南京','天津','东京'],
                activeindex:0,
                bgcolor:false,
                fzcolor:false,
                borcolor:false,
                bg:"orangered",
                co:'#fff'
            },
        })

计算属性

计算属性可以像绑定普通数据一样绑定在模板中绑定,不需要括号
计算属性写在computed:{}
计算属性默认只有get方法,在必要的时候可以写set方法

计算属性vs方法

计算属性:
计算属性是基于它们的响应式依赖进行缓存的。
只有跟计算属性相关的值或者数据发生改变时,才会重新执行计算属性
方法:
每当触发重新渲染时,调用方法将总会再次执行函数(在执行一遍)。
总结:计算属性可以提高性能优化

 <div id="app">
        <div>{{fullname}}</div>
    </div>
  computed:{
      fullname(){
             return '计算属性'
          },
        full: {
                    get() {
                        console.log('计算属性方法');
                        return this.fristname + '.' + this.lastname
                    },
                    set(val) {
                        let str = val.split('.')
                        console.log(str);
                        this.fristname = str[0]
                        this.lastname = str[1]
                    }
                },
  }

侦听器/监听器

监听器方法名跟监听的数据名相同
侦听器是根据数据的名称来定义的,该属性是监听该属性值是否发生变化有两个参数(新值,旧值)
侦听器写在watch:{}

姓名:的值发生变化时,监听器name就会打印新值和旧值

    <div id="app">
        <p>姓名:<input type="text" v-model="name"></p>
        <p>年龄:<input type="text" v-model="age"></p>{{myAge}}
        <div>
            <button @click="updata">修改</button>
            <p><input type="text" v-model="student.name"></p>
            <p><input type="text" v-model="student.age"></p>
            <p><input type="text" v-model="student.sex"></p>
        </div>
    </div>

当我点击修改按钮,触发updata()方法时,触发监听器,监听器能够打印新旧值
当我把updata方法换成setdata方法时,这时候值发生了改变,但是,监听器没有触发,所以要开启深度监听 deep: true,

new Vue({
            el: "#app",
            data: {
                name: '张三',
                age: 20,
                student: {
                    name: '张三',
                    age: 20,
                    sex: '男'
                }
            },
 methods: {
      updata() {
                    this.student = {
                        name: '李四',
                        age: 22,
                        sex: '女'
                    }
                },
      setdata(){
                    this.student.name="王五"
                    this.student.age="25"
                    this.student.sex="男"
                }
            },
 watch: { //新值  旧值
        //监听器的方法名跟监听的数据名相同
        name(nval, oval) {
                         //新值   旧值
              console.log(nval, oval);
           },
 student: {
                    //开启深度监听
                    deep: true,
                    //页面渲染完成时,先运行一次‘
                    immediate: true,
    注意:只有整个student对象变化了才会监听到,如果只是修改对象身上的属性,监听不到。
                    handler(nval, oval) {
                        console.log(nval, oval);
                    }
                },
})

过滤器

vue 允许你可以自定义一个过滤器,通常是一些文本格式,过滤器可以用在两个地方:双花括号插值和 v-bind 表达式 (后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示:

    <div id="app">
        <p>商品名称:{{goods.name}}</p>
        <h4>方法</h4>
        <p>商品名称:{{tofixed2(goods.price)}}</p>
        <h4> 计算属性 放回一个新的对象</h4>
        <p>商品名称:{{myGoods.price}}</p>
        <h4>过滤器</h4>
        <p>商品价格:{{goods.price | tofixed3}}</p>
        <p>商品价格(人民币):{{goods.price | tofixed3 | toRMB}}</p>
        <p>商品价格(美元):{{goods.price | tofixed3 | toUS}}</p>
    </div>

过滤器每次都是接收前一个表达式的值goods.price,作为第一个参数。
过滤器可以用链式的方式 用 |来 分开 如上代码所示:

new Vue({
            el: '#app',
            data: {
                goods: {
                    name: '小米手机',
                    price: 1999
                }
            },
            methods: {
                tofixed2(val) {
                    return val.toFixed(2)
                }
            },
            computed: {
                myGoods() {
                    let goods = {
                        name: this.goods.name,
                        price: this.goods.price.toFixed(2)
                    }
                    return goods
                }
            },
            //定义过滤器  可以链式使用
            filters: {
                tofixed3(val) {
                    return val.toFixed(2)
                },
                toRMB(val) {
                    return "¥" + val
                },
                toUS(val) {
                    return "$" + (val / 6.5).toFixed(2)
                }
            }
        })
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,271评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,725评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,252评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,634评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,549评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,985评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,471评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,128评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,257评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,233评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,235评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,940评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,528评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,623评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,858评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,245评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,790评论 2 339

推荐阅读更多精彩内容