溫馨提示×

溫馨提示×

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

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

vue中組件怎么用

發布時間:2021-08-10 10:10:30 來源:億速云 閱讀:148 作者:小新 欄目:web開發

這篇文章主要為大家展示了“vue中組件怎么用”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“vue中組件怎么用”這篇文章吧。

前言

組件是Vue.js最強大的功能之一。組件可以擴展HTML元素,封裝可重用的代碼。

在vue angular react三大前端框架的大前端時代。許多人選擇了vue,在 github 上的star,vue已經超過react的數量了。雖然star并不能代表vue更強,不過在發展速度上看來,vue確實很快。

vue中組件怎么用

在模塊化的前端時代,萬物皆組件,vue學習組件是必不可少的。

vue中組件怎么用

可是在大多數人熟悉了純html、jq之后,在初次接觸vue的組件時候,卻是滿臉蒙蔽。
今天咱們以最簡單的方式,帶vue小白童鞋們,步入組件的世界~

咱們今天講三種組件使用方式

  • 基本組件

  • 全局組件

  • 構造組件

1. 基本組件四步驟

  • 寫好組件(廢話~)

  • 在頁面種引用組件

  • 在components中聲明組件

  • 在頁面上使用

咱們以一個button子組件為例

項目src結構:

vue中組件怎么用

組件一般都放在components文件夾下:

1.寫好子組件:

<template>
 <button class="btn" :>
 <slot/> <!-- 插槽 -->
 </button>
</template>

<script>
export default {
 // 傳入子組件的參數寫到props
 props: {
 color: {
 type: String, // 顏色參數類型
 default: "#000" // 默認黑色
 }
 }
}
</script>

<style scoped>
 .btn {
 width: 110px;
 height: 60px;
 border-radius: 10px;
 border: none;
 font-size: 15px;
 }
</style>

2.3.4.父組件:

<template>
 <div id="app">
 <!-- 4. 在頁面上使用 -->
 <Button color="red">我是插槽的值</Button>
 </div>
</template>

<script>
// 2. 在頁面種引用組件
import Button from '@/components/Button.vue'
export default {
 name: "app",
 // 3. 在components中聲明組件
 components: {
 Button
 }
};
</script>

效果:

vue中組件怎么用

2. 全局組件五步驟

  • 寫好組件(還是廢話~)

  • 子組件添加install方法

  • 在 main.js 中引用

  • 使用 Vue.use 方法

  • 在頁面上使用

1.子組件還是那樣~~:

2. 子組件添加install方法

Button.js :

import ButtonComponent from './Button.vue'

// 添加install方法 (插件方法)
const Button = {
 install: function (Vue) {
 Vue.component("Button", ButtonComponent);
 }
}

// 導出Button
export default Button

當然 你可以處理多個全局組件:

import ButtonComponent1 from './Button1.vue'
import ButtonComponent2 from './Button2.vue'
import ButtonComponent3 from './Button3.vue'

const buttonList = [
 ButtonComponent1,
 ButtonComponent2,
 ButtonComponent3
];
// 添加install方法 (插件方法)
const Button = {
 install: function (Vue) {
 buttonList.forEach(button=>{
 // 這里 使用每個組件的 name 屬性作為組件名
 Vue.component(button.name, button);
 })
 }
}

// 導出Button
export default Button

3.4. main.js

import Vue from 'vue'
import App from './App.vue'
// 3
import Button from '@/components/Button.js'
// 4
Vue.use(Button);
new Vue({
 render: h => h(App),
}).$mount('#app')

5. 在頁面上使用
app.vue:

<template>
 <div id="app">
 <!-- 5. 在頁面上使用 -->
 <Button color="blue">我是全局按鈕</Button>
 </div>
</template>

效果如下:

vue中組件怎么用

2. 構造組件四步驟

  • 寫好組件(還**是廢話~)

  • vue.extend構建組件

  • 掛載 Vue.prototype

  • 在js中使用

1.寫好子組件:

<template>
 <p class="Message">{{value}}</p>
</template>

<script>
export default {
 data() {
 return {
  value: "我是一個彈框"
 };
 }
};
</script>

<style>
.Message {
 position: fixed;
 bottom: 30px;
 width: 200px;
 background-color: rgba(0, 0, 0, 0.5);
 color: #fff;
 border-radius: 10px;
 left: 50%;
 transform: translateX(-50%);
 line-height: 30px;
 text-align: center;
 font-size: 15px;
 animation: messageFade 3s 1;
}
/* 加個簡單動畫 */
@keyframes messageFade {
 0% {
 opacity: 0;
 -webkit-transform: translate3d(-50%, 80%, 0);
 transform: translate3d(-50%, 80%, 0);
 }
 16% {
 opacity: 1;
 -webkit-transform: translate3d(-50%, 0, 0);
 transform: translate3d(-50%, 0, 0);
 }
 84% {
 opacity: 1;
 -webkit-transform: translate3d(-50%, 0, 0);
 transform: translate3d(-50%, 0, 0);
 }
 100% {
 opacity: 0;
 -webkit-transform: translate3d(-50%, 80%, 0);
 transform: translate3d(-50%, 80%, 0);
 }
}
</style>

2. vue.extend構建組件

Message.js :

import Vue from 'vue';
import Message from './Message.vue';
// 構造組件
const MessageConstructor = Vue.extend(Message);
// 設置刪除組件
const removeDom = (target) => {
 target.parentNode.removeChild(target);
};
// 構造組件添加關閉方法
MessageConstructor.prototype.close = function() {
 this.visible = false;
 removeDom(this.$el);
};

const MessageDiv = (options) => {
 // 實例化組件
 const instance = new MessageConstructor({
  el: document.createElement('div'),
  // 組件參數,運用到組件內的data
  data: options,
 });
 // 在body添加組件
 document.body.appendChild(instance.$el);
 Vue.nextTick(() => {
  instance.timer = setTimeout(() => {
   // 定時關閉組件
   instance.close();
  }, 3000);
 });
 return instance;
};

export default MessageDiv;

3. 掛載 Vue.prototype

main.js :

import Message from '@/components/Message.js'
Vue.prototype.$message = Message;

4. 使用:

<template>
 <div id="app">
 <Button color="blue" @click.native="msg">我是全局按鈕</Button>
 </div>
</template>

<script>
import Button from "@/components/Button.vue";
export default {
 name: "app",
 components: {
 Button
 },
 methods: {
 msg() {
  // 4. 使用構造組件
  this.$message({value:'我是構造組件'});
 }
 }
};
</script>

效果:

vue中組件怎么用

以上是“vue中組件怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

vue
AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女