溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

vuejs中實(shí)例和組件的區(qū)別有哪些

發(fā)布時(shí)間:2021-09-28 15:51:47 來(lái)源:億速云 閱讀:140 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要介紹了vuejs中實(shí)例和組件的區(qū)別有哪些,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

區(qū)別:1、實(shí)例有el掛載點(diǎn),組件沒(méi)有。2、實(shí)例中是“data:{}”,組件中是“data(){return{}}”。3、vue實(shí)例的html元素是直接渲染到頁(yè)面中的;而組件的html元素是定義在template上,通過(guò)調(diào)用再渲染到頁(yè)面中的。

本教程操作環(huán)境:windows7系統(tǒng)、vue2.9.6版,DELL G3電腦。

上次寫(xiě)vue單組件項(xiàng)和路由的時(shí)候,想到一個(gè)問(wèn)題。new Vue({…})是一個(gè)Vue實(shí)例,那么組件是Vue實(shí)例嗎?

分析

之前說(shuō)了,有兩種開(kāi)發(fā)方式。一個(gè)是基于瀏覽器的(即直接在script中引入main.js),還有一個(gè)是vue-cli搭建出來(lái)的基于命令行的開(kāi)發(fā)方式(一個(gè)vue項(xiàng)目).

因?yàn)閷?shí)際項(xiàng)目大部分都用命令行開(kāi)發(fā)方式,所以還是說(shuō)命令行開(kāi)發(fā)方式里的組件。

在項(xiàng)目的main.js

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({//這里就是一個(gè)vue實(shí)例
  el: '#app',//el掛載點(diǎn)
  router,
  components: { App },
  template: '<App/>',//此處引根組件
})

而App.vue代碼中

<template>
  <div id="app">
       <div class="welcome">welcome! {{name}}, you are {{age}} years old</div>
    <router-view/>
  </div>
</template>
<script>
export default {
  name: 'App',
  data:function(){
    return {
      name:'wangyue',
      age:'25'
    }
  },
  }
</script>

<style>
  .welcome{
    font-size: 32px;
    color: blueviolet;
  }
</style>

效果圖如下,紫色文字之下的可以忽略不看,這里是我路由展示的內(nèi)容。
vuejs中實(shí)例和組件的區(qū)別有哪些
放大比較一下

vuejs中實(shí)例和組件的區(qū)別有哪些
vuejs中實(shí)例和組件的區(qū)別有哪些

vuejs中實(shí)例和組件的區(qū)別

組件的data是一個(gè)function非組件是data:{},組件沒(méi)有el掛載點(diǎn)這個(gè)選項(xiàng)。按官網(wǎng)來(lái)說(shuō),組件是可復(fù)用的 Vue 實(shí)例,且?guī)в幸粋€(gè)名字。

在vue項(xiàng)目中,一般只有一個(gè)VUE實(shí)例在main.js中定義,其他都是vue組件實(shí)例。其實(shí)都是vue實(shí)例,但為了方便區(qū)分,我就這么說(shuō)了。根組件之外,components中還有很多小組件。

即:

1、vue實(shí)例有el指定掛載元素,組件沒(méi)有,因?yàn)榻M件也是通過(guò)調(diào)用在渲染頁(yè)面,直接通過(guò)調(diào)用組件名渲染;

2、實(shí)例和組件的data屬性形式不同

vue實(shí)例中data屬性:data:{“name”:“aa”,“age”:18},

組件中的data屬性:data(){ return{“name”:“aa”,“age”:18} },

3、vue實(shí)例的html元素是直接渲染到頁(yè)面中,而組件的html元素是定義在template上,通過(guò)調(diào)用再渲染到頁(yè)面

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“vuejs中實(shí)例和組件的區(qū)別有哪些”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

vue
AI