Vue(3)--綁定樣式&計算屬性&偵聽器&過濾器

一、綁定樣式

1贯要、使用:class對象綁定樣式

注意: :class綁定樣式時,對象的屬性是類選擇器名稱椭住,屬性值返回為true時崇渗,則表示添加該選擇器。

1.1、創(chuàng)建vue容器

 <div id="app">
        <ul class="city">
            <!-- :class綁定樣式是宅广,對象的屬性是類選擇器名稱葫掉,屬性值返回true,表示添加該選擇器 -->
            <li :class='{active:index===activeIndex}' @click='activeIndex=index' v-for='(item,index) in citys'
                :key='index'>{{item}}</li>
        </ul>
        <ul class="city">
            <li :class="index===activeIndex?'active':''" @click='activeIndex=index' v-for='(item,index) in citys'
                :key='index'>{{item}}</li>
        </ul>
        <hr style="margin: 10px 0;">
        <button @click='bgColor=true'>添加背景顏色</button>
        <button @click='fontColor=true'>添加文本顏色</button>
        <button @click='border=true'>添加容器邊框</button>
        <div class="box1" :class='{bgColor:bgColor,fontColor:fontColor,border:border}'>好好學(xué)習(xí)vue</div>

1.2跟狱、構(gòu)建容器樣式

<style>
        * {
            list-style: none;
            margin: 0;
            padding: 0;
        }

        .city {
            display: flex;
            margin: 10px;
        }

        .city li {
            border: 1px solid #ccc;
            padding: 4px 6px;
        }

        .city li.active {
            background-color: burlywood;
            color: white;
        }

        .box1 {
            width: 200px;
            height: 200px;
            padding: 10px;
        }

        .bgColor {
            background-color: skyblue;
        }

        .fontColor {
            color: tomato;
        }

        .border {
            border: 2px solid gray;
        }
    </style>

1.3俭厚、創(chuàng)建vue對象

 <script src="../js/Vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                activeIndex: 0,
                citys: ['北京', '南京', '上海', '廣州'],
                //是否添加北京顏色
                bgColor: false,
                //是否添加文本顏色
                fontColor: false,
                //是否顯示邊框
                border: false,
                //定義背景顏色
                bgc: 'pink',
                //定義文本顏色
                fc: 'blue'
            }
        })
    </script>

2、使用:class數(shù)組三元表達(dá)式綁定對象

       <hr style="margin: 10px 0;">
        <div class="box1" :class="[bgColor?'bgColor':'',fontColor?'fontColor':'',border?'border':'']">好好學(xué)習(xí)vue</div>

3驶臊、使用:style綁定對象

注意::style綁定樣式時挪挤,對象的屬性名稱是css樣式的名稱(要使用小駝峰命名法),屬性值是具體的樣式值

 <!-- :style綁定樣式時关翎,對象的屬性名稱是css樣式的名稱(要使用小駝峰命名法)扛门,屬性值是具體的樣式值 -->
        <div class="box1" :style="{backgroundColor:bgc,color:fc}">好好學(xué)習(xí)vue
            <p>背景色:<input type="text" v-model='bgc'></p>
            <p>文本色:<input type="text" v-model='fc'></p>
        </div>

二、計算屬性

注意:計算屬性與vue對象里的方法相比 纵寝,計算屬性的優(yōu)勢是尖飞,有緩存,當(dāng)頁面數(shù)據(jù)發(fā)生變化時店雅,所有的方法都要重新執(zhí)行政基,但是只有當(dāng)計算屬性用到的數(shù)據(jù)發(fā)生變化時,計算屬性才會重新執(zhí)行闹啦。

  <div id="app">
        <p>姓:<input type="text" v-model="firstName"></p>
        <p>名:<input type="text" v-model="lastName"></p>
        <p>地址:<input type="text" v-model="address"></p>
        <!-- 計算屬性的優(yōu)勢是沮明,有緩存,當(dāng)頁面數(shù)據(jù)發(fā)生變化時窍奋,所有的方法都要重新執(zhí)行荐健,當(dāng)計算屬性用到的數(shù)據(jù)發(fā)生變化時,計算屬性才會重新執(zhí)行 -->
        <p>方法返回姓名:<input type="text" v-model="fullName2()"></p>
        <p>計算屬性返回姓名:<input type="text" v-model="fullName"></p>
        <hr>
        <ul>
            <li v-for='(item,index) in goodses' :key='index'>{{item.name}}--{{item.price}}
                <button @click='delGoods(index)'>刪除</button>
            </li>
            <li>總價是--{{totalPrice}}元</li>
        </ul>
    </div>
    <script src="../js/Vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                firstName: '張',
                lastName: '李',
                address: '南京',
                goodses: [
                    {
                        name: '油煙機(jī)',
                        price: 2599
                    },
                    {
                        name: '冰箱',
                        price: 1599
                    },
                    {
                        name: '空調(diào)',
                        price: 3599
                    }
                ]
            },
            methods: {
                fullName2(){
                    return this.firstName+'.'+this.lastName
                },
                delGoods(index){
                    this.goodses.splice(index,1)
                }
                // totalPrice(){
                //     console.log('我在計算總價格');
                //     let sum = 0
                //     this.goodses.forEach(r => {
                //         sum += r.price
                //     })
                //     return sum
                // }
            },
            //用于定義計算屬性
            computed: {
                totalPrice(){
                    console.log('我在計算總價格');
                    let sum = 0
                    this.goodses.forEach(r => {
                        sum += r.price
                    })
                    return sum
                },
                //在這里面定義的是方法琳袄,計算屬性默認(rèn)情況下只能讀江场,不能改
                fullName(){
                    console.log('我是計算屬性')
                    return this.firstName+'.'+this.lastName
                },
                // //定義完整結(jié)構(gòu)的計算屬性
                // fullName: {
                //     //get方法,用于返回計算屬性的值
                //     get() {
                //         return this.firstName + '.' + this.lastName
                //     },
                //     // set方法窖逗,修改計算屬性的結(jié)果址否,該方法接收一個參數(shù)是最新的值
                //     set(){
                //         let arr = val.spilt('.')
                //         this.firstName = arr[0]
                //         this.lastName = arr[1]
                //     }
                // }
            }
        })

三、偵聽器

注意:數(shù)據(jù)偵聽器--根據(jù)屬性的名稱碎紊,定義一個方法佑附,用于偵聽該屬性的變化。這個方法仗考,可以傳兩個參數(shù)音同,第一個參數(shù)是最新值,第二個參數(shù)是舊值

<div id="app">
        <p>姓名:<input type="text" v-model='name'></p>
        <p>年齡:<input type="text" v-model='age'>{{myAge}}</p>
        <hr>
        <h2>學(xué)生信息</h2>
        <button @click='resetStudent'>修改學(xué)生信息</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>
    <script src="../js/Vue.js"></script>
    <script>
        Vue.config.productionTip = false
        new Vue({
            el:"#app",
            data:{
                name:'張三',
                age:22,
                student:{
                    name:'李四',
                    age:20,
                    sex:'女'
                }
            },
            methods: {
                resetStudent(){
                    this.student = {
                        name:'王五',
                        age:33,
                        sex:'男'
                    }
                }
            },
            //數(shù)據(jù)偵聽器
            watch:{
                //根據(jù)屬性的名稱秃嗜,定義一個方法权均,用于偵聽該屬性的變化
                //這個方法顿膨,可以傳兩個參數(shù),第一個參數(shù)是最新值叽赊,第二個參數(shù)是舊值
                name(nval,oval){
                    //比如虽惭,當(dāng)name屬性發(fā)生變化時,重新發(fā)送Ajax請求獲取新的數(shù)據(jù)
                    console.log(nval,oval);
                },
                // age(nval,oval){
                //     console.log(nval,oval);
                // },
                // student(nval,oval){
                //     console.log(nval,oval);
                // },
                //偵聽對象蛇尚,需要開啟深度監(jiān)視
                student:{
                    //開啟深度監(jiān)視
                    deep:true,
                    //開始運(yùn)行一次(注意:這種情況下芽唇,舊值是undefined)
                    immediate:true,
                    //定義監(jiān)視函數(shù)
                    handler(nval,oval){
                        //開啟深度監(jiān)視,舊值已經(jīng)沒有意義取劫,因?yàn)閷ο笫且妙愋偷?                        //對象的屬性值已經(jīng)改了匆笤,就沒有舊的屬性值
                        console.log(nval,oval);
                    }
                }
            },
            //計算屬性也有監(jiān)視對象的能力
            computed:{
                myAge(){
                    //當(dāng)計算屬性里面用到的數(shù)據(jù)發(fā)生變化時,會重新執(zhí)行計算屬性
                    //只是計算屬性必須要在模板中使用
                    console.log(this.age);
                    return this.age
                }
            }

        })
    </script>

四谱邪、過濾器

注意:過濾器在模板中通過管道符| 的方式來調(diào)用炮捧,過濾器可以鏈?zhǔn)秸{(diào)用,就是之前已經(jīng)過濾完成的結(jié)果惦银,繼續(xù)傳遞給下一個過濾器咆课,注意順序。

 <div id="app">
        <p>商品名稱:{{goods.name}}</p>
        <p>商品價格:{{toFixed2(goods.price)}}</p>
        <p>商品價格:{{myGoods.price}}</p>
        <!-- 通過管道符 | 調(diào)用過濾器扯俱,其實(shí)就是調(diào)用這個方法书蚪,將值傳過去, -->
        <p>商品價格(人民幣):{{goods.price | toFixed2 | toRMB}}
            <input type="text" :value='goods.price | toFixed2'>
        </p>
        <!-- 過濾器可以鏈?zhǔn)秸{(diào)用迅栅,就是之前已經(jīng)過濾完成的結(jié)果殊校,繼續(xù)傳遞給下一個過濾器,注意順序 -->
        <p>商品價格(美元):{{goods.price | toFixed2 | toUS}}</p>
    </div>
    <hr>
    <div id="app2">
        <p>商品名稱:{{goods.name}}</p>
        <p>商品價格(美元):{{goods.price | toFixed2 }}</p>
    </div>
    <script src="../js/Vue.js"></script>
    <script src="../l03/index.js"></script>
    <script>
        Vue.config.productionTip = false
        new Vue({
            el:'#app2',
            data:{
                goods:{
                    name:'華為手機(jī)',
                    price:4311.6666
                }
            }
        })
        
        new Vue({
            el: '#app',
            data: {
                goods: {
                    name: '小米手機(jī)',
                    price: 2566.5555
                }
            },
            //定義方法读存,過濾商品的價格
            methods: {
                toFixed2(val) {
                    return val.toFixed(2)
                }
            },
            //定義一個計算屬性
            computed: {
                myGoods() {
                    let goods = {
                        name: this.goods.name,
                        price: this.goods.price.toFixed(2)
                    }
                    return goods
                }
            },
            //定義過濾器
            filters: {
                //過濾器在模板中通過管道符| 的方式來調(diào)用
                toFixed2(val) {
                    return val.toFixed(2)
                },
                //返回人民幣數(shù)據(jù)
                toRMB(val) {
                    return '¥' + val
                },
                //返回美元數(shù)據(jù)
                toUS(val) {
                    return '$' + (val / 6.5).toFixed(2)
                }
            }
        })
    </script>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末为流,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子让簿,更是在濱河造成了極大的恐慌敬察,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件尔当,死亡現(xiàn)場離奇詭異莲祸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)居凶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進(jìn)店門虫给,熙熙樓的掌柜王于貴愁眉苦臉地迎上來藤抡,“玉大人侠碧,你說我怎么就攤上這事〔颍” “怎么了弄兜?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我替饿,道長语泽,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任视卢,我火速辦了婚禮踱卵,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘据过。我一直安慰自己惋砂,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布绳锅。 她就那樣靜靜地躺著西饵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鳞芙。 梳的紋絲不亂的頭發(fā)上眷柔,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機(jī)與錄音原朝,去河邊找鬼驯嘱。 笑死,一個胖子當(dāng)著我的面吹牛喳坠,可吹牛的內(nèi)容都是我干的宙拉。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼丙笋,長吁一口氣:“原來是場噩夢啊……” “哼谢澈!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起御板,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤锥忿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后怠肋,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體敬鬓,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年笙各,在試婚紗的時候發(fā)現(xiàn)自己被綠了钉答。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡杈抢,死狀恐怖数尿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情惶楼,我是刑警寧澤右蹦,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布诊杆,位于F島的核電站,受9級特大地震影響何陆,放射性物質(zhì)發(fā)生泄漏晨汹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一贷盲、第九天 我趴在偏房一處隱蔽的房頂上張望淘这。 院中可真熱鬧,春花似錦巩剖、人聲如沸慨灭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽氧骤。三九已至,卻和暖如春吃引,著一層夾襖步出監(jiān)牢的瞬間筹陵,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工镊尺, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人庐氮。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像弄砍,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子音婶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評論 2 355

推薦閱讀更多精彩內(nèi)容