91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何從面向對象思維理解Vue組件

發布時間:2022-03-24 10:42:50 來源:億速云 閱讀:209 作者:iii 欄目:web開發

這篇文章主要講解了“如何從面向對象思維理解Vue組件”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何從面向對象思維理解Vue組件”吧!

什么是組件

用面向對象的思維去理解Vue組件,可以將所有的事物都抽象為對象,而類或者說是組件,都具有屬性和操作。

如抽取人類為組件,其基本的屬性有姓名、年齡、國籍;基本的方法有吃飯、睡覺、跑步等。

<script>
export default {
    name: "person",
    props: {
        name: {
            type: String,
            required: false,
            default: "無名氏"
        },
        age: {
            type: Number,
            required: false,
            default: 0
        },
        country: {
            type: String,
            required: false,
            default: "地球人"
        }
    },
    methods: {
        eat() {
            consloe.log("吃飯")
        },
        sleep() {
            consloe.log("睡覺")
        },
        run() {
            consloe.log("跑步")
        }
    }
}
</script>

在面向對象中,構造函數可以為類初始化全局變量,所以這種方式同樣可以用在組件中

<person :age="20" :name=""小明"" :country=""中國人""></person>

組件封裝了數據以及操作,有進則有出,我們不用關心組件內發生了什么,我們只需要結果和呈現出來的效果如何。

自定義事件

外界不可以直接訪問使用或訪問組件的屬性,該如何做?

使用$emit自定義事件,可以實現外界獲取組件屬性。

<template>
    ...
    <button @click="handleClick">點擊</button>
</template>

<script>
export default {
    name: "person",
    methods: {
        handleClick() {
            this.$emit("getPerson", {
                age: this.age,
                name: this.name,
                country: this.country
            })
        }
    }
}
</script>

外界調用組件時添加自定義函數@getPersonv-on:click="getPerson"

<template>
    <div>
        <person :age="20" :name=""小明"" :country=""中國人"" @getPerson="getPerson"></person>
    </div>
</template>

<script>
export default {
    name: "test",
    methods: {
        getPerson(info) {
            consloe.log(info)
        }
    }
}
</script>

實際案例

如何從面向對象思維理解Vue組件

在網頁開發中,你可能會用到標簽,而你可能會想到標簽不可能在一個頁面使用一次,可能是多次使用到。你還可能會想到因為不同的情況而自定義一些寬度、高度和顏色。

所以可以將標簽相關的HTML代碼和CSS封裝到組件中,對外,我們暴露width、height和type參數。在使用時,因為不同的情況而需要自定義,那么傳遞參數即可。

<template>
    <view
        :style="{ width: width, height: height }"
        :class="["owl-tag-" + type]"
        class="owl-tag text-xs flex align-center justify-center"
    >
        <slot></slot>
    </view>
</template>

<script>
    name: "owl-tag",
    props: {
        // 可傳入有效值為 primary | gray
        type: {
            type: String,
            default: "primary"
        },
        width: {
            type: String,
            required: false
        },
        height: {
            type: String,
            required: false
        }
    }
</script>

<style>
.owl-tag {
    border-radius: 8rpx;
    padding: 6rpx 10rpx;
}

.owl-tag-primary {
    color: white;
    background-color: #87cefa;
}

.owl-tag-gray {
    color: #81868a;
    background-color: #f0f1f5;
}
</style>

這些工作做好了,一個組件就被我們定義好了。想用就調用,想改就傳參,這就是組件的好處。

<template>
    <owl-tag
        :type=""primary""
        :height=""45rpx""
        :width=""120rpx""
    >
        官方帖
    </owl-tag>
</template>

改變type的值為gray,呈現的效果如下:

如何從面向對象思維理解Vue組件

感謝各位的閱讀,以上就是“如何從面向對象思維理解Vue組件”的內容了,經過本文的學習后,相信大家對如何從面向對象思維理解Vue組件這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

怀柔区| 牡丹江市| 涟水县| 英吉沙县| 吕梁市| 莱芜市| 高密市| 平江县| 土默特右旗| 中阳县| 银川市| 泰来县| 凯里市| 通州区| 临海市| 永德县| 榆社县| 磐安县| 武陟县| 泌阳县| 阳朔县| 贺州市| 金堂县| 通海县| 工布江达县| 河南省| 延津县| 虞城县| 邯郸市| 平罗县| 阳东县| 邹城市| 棋牌| 瓮安县| 周宁县| 武安市| 兴宁市| 昌图县| 贵阳市| 忻州市| 琼海市|