中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Vue全局變量和局部變量如何實現

發布時間:2022-11-17 09:44:24 來源:億速云 閱讀:151 作者:iii 欄目:開發技術

這篇文章主要介紹“Vue全局變量和局部變量如何實現”,在日常操作中,相信很多人在Vue全局變量和局部變量如何實現問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Vue全局變量和局部變量如何實現”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

局組件和局部組件

1.先定義組件   Vue.component('組件名', { 組件模板對象 })

注意: 組件名不要使用原生的標簽名, 若組件名定義時用的是駝峰命名法, 則調用時用中劃線分割后小寫
例如: 組件-->mtText   使用時-->   <my-text></my-text>

2.配置組件的模板  注意: 組件的模板內容有且只有一個根元素

3.在視圖層里調用 ,用雙標簽

4.組件是一個獨立的作用域, 也可以看成一個特殊的vue實例, 可以有data, methods,computed等等

注意: 組件的data是函數, 函數中需要返回一個對象作為組件的data

全局組件案例

<body>
<div id="app">
  <my-component></my-component>
</div>
<script src="lib/vue-2.4.0.js"></script>
<script>
//全局組件
  Vue.component('myComponent',{
    //1.組件的內容/模板
    template: '<div><div>頭部組件</div><h2 @click="fn">呵呵{{msg}}</h2></div>',
    data(){
      return {
        msg:'hello,組件'
      }
    },
    methods:{
      fn(){
        console.log(this.msg);
      }
    }
  })
  let vm = new Vue({
    el:"#app",
    data:{
    },
    methods:{

    },

  })
</script>
</body>

局部組件案例

<body>
<div id="app">
  <my-component></my-component>
  <my-test></my-test>
</div>
<template id="box1">
  <h2>haha</h2>
</template>
<template id="box2">
  <div>
    <ul>
      <li v-for="item in arr">
        {{ item }}
      </li>
    </ul>
  </div>
</template>
<script src="lib/vue-2.4.0.js"></script>
<script>
let vm = new Vue({
    el:"#app",
    data:{
    },
    methods:{

    },
    //局部子組件
    components:{
      // 組件名: {配置項}
      "myComponent":{
        template:'#box1',
        data(){
          return {
            msg:"哈哈"
          }
        }
      },
      "myTest":{
        template:"#box2",
        data(){
          return {
            arr:[1,2,3,4]
          }
        }
      }
    }
  })
</script>
</body>

組件切換:法一

<body>
<div id="app">
  <a href="" @click.prevent=" rel="external nofollow" rel="external nofollow" flag=true">登錄</a>
  <a href="" @click.prevent=" rel="external nofollow" rel="external nofollow" flag=false">注冊</a>
  <login v-if="flag"></login>
  <register v-else="flag"></register>
</div>
<script src="lib/vue-2.4.0.js"></script>
<script>
  Vue.component("login",{
    template:"<h2>登錄組件</h2>"
  })
  Vue.component("register",{
    template:"<h2>注冊組件</h2>"
  })
  let vm = new Vue({
    el:"#app",
    data:{
      flag: false
    },
    methods:{
    },
  })
</script>
</body>

組件切換:法二

<style>
    .red{
      color:red;
    }
    .v-enter{
      opacity:0;
      transform: translateX(150px);
    }
    .v-leave-to{
      opacity:0;
      transform: translateX(-150px);
    }
    .v-enter-active,
    .v-leave-active{
      transition: all 0.5s;
      position: absolute;
    }
  </style>
<body>
<div id="app">
  <a href="" :class=" rel="external nofollow" rel="external nofollow" {red: flag=='login'}" @click.prevent="flag='login'">登錄</a>
  <a href="" :class=" rel="external nofollow" rel="external nofollow" {red: flag=='register'}" @click.prevent="flag='register'">注冊</a>
  <!-- vue提供了一個標簽 component標簽(理解為一個占位符), 用來展示對應名稱的組件 :is屬性設置指定的組件名 -->
  <transition>
    <component :is="flag"></component>
  </transition>
</div>
<script src="lib/vue-2.4.0.js"></script>
<script>
  Vue.component("login",{
    template:"<h2>登錄組件</h2>"
  })
  Vue.component("register",{
    template:"<h2>注冊組件</h2>"
  })
  let vm = new Vue({
    el:"#app",
    data:{
      flag: "login"
    },
    methods:{

    },
  })
</script>
</body>

父組件向子組件傳值

<body>
<div id="app">
  <my-component :fromfather="father"></my-component>
</div>
<template id="box1">
  <h2 @click="change">
    {{ fromfather }}
    子組件的數據
  </h2>
</template>
<template id="grandSon">
  <h2>孫子組件的數據</h2>
</template>
<!--1.子組件不能訪問父組件的數據
2. 解決辦法: ①在引用子組件時, 通過屬性綁定 v-bind方法, 把需要傳遞給子組件的數據以綁定的形式傳過來
       ② 在子組件配置項里添加 props: ['傳遞過來的數據']-->
<script src="lib/vue-2.4.0.js"></script>
<script>
  let vm = new Vue({
    el:"#app",
    data:{
      father:'啊~~這是父組件的數據'
    },
    methods:{
    },
    //局部子組件
    components:{
      // 組件名: {配置項}
      "myComponent":{
        template:'#box1',
        data(){
          return {
            msg:"哈哈"
          }
        },
        //在子組件配置項里添加 props: ['傳遞過來的數據']
        //注意: 組件中所有的props中的數據, 都是通過父組件傳遞給子組件的, props中的數據是只讀, 無法修改
        props:['fromfather'],
        methods:{
          change(){
            // this.fromfather = "被修改了"
          }
        },
        //局部子子組件
        components:{
          'grandSon':{
            template:'#grandSon'
          }
        }
      }
    }
  })
</script>
</body>

為什么要使用Vue

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網頁分割成可復用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網頁中相應的地方,所以越來越多的前端開發者使用vue。

到此,關于“Vue全局變量和局部變量如何實現”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

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

vue
AI

民县| 镇原县| 都兰县| 华容县| 象山县| 鄂托克旗| 马边| 东乡县| 安国市| 洪湖市| 苏尼特右旗| 东乌珠穆沁旗| 鄂温| 沅江市| 应用必备| 巧家县| 张北县| 玉环县| 新津县| 门源| 新干县| 丹棱县| 盐边县| 原阳县| 宜春市| 石林| 噶尔县| 什邡市| 陆川县| 泗阳县| 正定县| 理塘县| 舒兰市| 玛曲县| 永新县| 房产| 巨野县| 隆德县| 宜春市| 绵阳市| 穆棱市|