欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中實現(xiàn)子組件相互切換且數(shù)據(jù)不丟失的策略詳解

 更新時間:2024年03月22日 10:03:34   作者:月下星辰  
項目為數(shù)據(jù)報表,但是一個父頁面中有很多的子頁面,而且子頁面中不是相互關(guān)聯(lián),但是數(shù)據(jù)又有聯(lián)系,所以本文給大家介紹了vue中如何實現(xiàn)子組件相互切換,而且數(shù)據(jù)不會丟失,并有詳細的代碼供大家參考,需要的朋友可以參考下

項目場景:

今天的項目場景: 項目為數(shù)據(jù)報表,但是一個父頁面中有很多的子頁面,而且子頁面中不是相互關(guān)聯(lián),但是數(shù)據(jù)又有聯(lián)系.

問題描述

子頁面相互切換的時候之前填寫好的數(shù)據(jù)會丟失,無法保存.這樣想提交所有的子頁面的數(shù)據(jù)就出現(xiàn)問題.

原因分析:

分析原因就是子組件在切換的時候,我使用的是動態(tài)組件,這個動態(tài)組件的底層原理是v-if去判斷,這樣子組件就有一個消失重建的過程. 如何讓子組件保存不消失.而且還需要在切換回來的時候其他子頁面的數(shù)據(jù)改了之后,當前的子頁面的數(shù)據(jù)也會同步?

解決方案:

vue中有一個延緩什么周期的組件,keep-alive 

將子組件用keep-alive包裹之后

  <keep-alive>
              <component :is="'tab' + active" :ref="'tab' + active"></component>
  </keep-alive>

整體代碼

<template>
  <div class="userbox">
    <comm-card>
      <!-- title 標題  v-bind  :  v-on @  v-slot # -->
      <template #title>
        <div class="box">
          <span>有子組件-案例2</span>
        </div>
      </template>
 
      <!-- content 正文-->
      <template #content>
        <div style="width: 100%">
          <div class="tabtitle" style="margin-bottom: 20px">
            <el-tag
              v-for="tag in tags"
              :key="tag.name"
              closable
              :type="tag.type"
              style="margin-left: 20px; width: 100px; text-align: center"
              @click="tabclicks(tag.id)"
            >
              {{ tag.name }}
            </el-tag>
          </div>
          <div class="tabbox">
            <keep-alive>
              <component :is="'tab' + active" :ref="'tab' + active"></component>
            </keep-alive>
          </div>
          <div>
            <el-button type="primary" @click="save()">提交</el-button>
          </div>
        </div>
      </template>
    </comm-card>
  </div>
</template>
 
<script>
/*
  1, 不能讓子組件在切換的時候,值消失,必須使用緩存技術(shù), v-show 或者 keep-alive
  2, 為了提高性能或者簡化代碼,可以使用component 動態(tài)組件加載技術(shù)
  3, 使用ref技術(shù)獲取子組件的值
  4, 結(jié)合tab欄點擊事件,實現(xiàn)獲取值的時機
*/
// 第一步 引入
import commCard from "../../components/commonCard";
import tab1 from "./components/sun1.vue";
import tab2 from "./components/sun2.vue";
import tab3 from "./components/sun3.vue";
// 第二步 注冊到我們的components中
export default {
  components: {
    commCard,
    tab1,
    tab2,
    tab3,
  },
  data() {
    return {
      active: 1,
      tags: [
        { id: 1, name: "菜單1", type: "" },
        { id: 2, name: "菜單2", type: "success" },
        { id: 3, name: "菜單3", type: "warning" },
      ],
      values: {}, // 存不同的子組件的值
    };
  },
  methods: {
    tabclicks(value) {
      //在點擊的時候開始存入上一個子組件的值
      this.values[this.active - 1] = this.$refs["tab" + this.active].obj;
      // 切換到已經(jīng)點擊的子組件上
      this.active =
        this.tags.findIndex((ele) => {
          return ele.id == value;
        }) + 1;
    },
    save() {
      //解決方案,將不同組件的值用不懂對象名稱包裹
      // 獲取當前子組件的值
      this.values[this.active - 1] = this.$refs["tab" + this.active].obj;
      // 打印所以得子組件的值
      console.log(this.values);
    },
  },
};
</script>
 
<style lang="less" scoped>
.box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
</style>

完美解決問題!

番外:component實現(xiàn)組件切換

1.代碼:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>組件切換</title>
</head>

<body>
    <div class="body">
        <input type="button" value="登錄" @click="name='login'">
        <input type="button" value="注冊" @click="name='register'">
        <input type="button" value="首頁" @click="name='index'">
        
        <!-- 使用 component 元素實現(xiàn)組件之間的切換 -->
        <component :is="name"></component>
    </div>


    <!-- 登錄組件 -->
    <template id="login">
        <h3>我是登錄組件</h3>
    </template>

    <!-- 注冊組件 -->
    <template id="register">
        <h3>我是注冊組件</h3>
    </template>

    <!-- 首頁組件 -->
    <template id="index">
        <h3>我是首頁組件</h3>
    </template>


    <script src="../lib/vue-2.4.0.js"></script>
    <script>
        /* 登錄組件 */
        Vue.component("login", {
            template: "#login"
        })
        /* 注冊組件 */
        Vue.component("register", {
            template: "#register"
        })
        /* 首頁組件 */
        Vue.component('index', {
            template: "#index"
        })

        let vm = new Vue({
            el: ".body",
            data: {
                name:'login'
            }
        })
    </script>
</body>

</html>

效果:

講解:

(1)定義三個不同的組件

(2)在 vue 實例的控制區(qū)域中寫入 component 元素,設(shè)置 is 屬性(需要通過 v-bind 進行數(shù)據(jù)綁定),其值為將要顯示的組件的名稱

(3)在 data 中定義一個 name 值,其初始值為 ‘login’(注意要用引號包裹起來)

(4)為各個按鈕設(shè)置事件綁定,點擊時修改 name 為對應的值(注意 name 的值要用引號包裹起來)

以上就是vue中實現(xiàn)子組件相互切換且數(shù)據(jù)不丟失的策略詳解的詳細內(nèi)容,更多關(guān)于vue子組件相互切換的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • buildAdmin開源項目引入四種圖標方式詳解

    buildAdmin開源項目引入四種圖標方式詳解

    這篇文章主要為大家介紹了buildAdmin開源項目引入四種圖標方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • vue中process.env的具體使用

    vue中process.env的具體使用

    本文主要介紹了vue中process.env的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • Vue實現(xiàn)固定定位圖標滑動隱藏效果

    Vue實現(xiàn)固定定位圖標滑動隱藏效果

    移動端頁面,有時候會出現(xiàn)一些固定定位在底部圖標,比如購物車等。這篇文章主要介紹了Vue制作固定定位圖標滑動隱藏效果,需要的朋友可以參考下
    2019-05-05
  • 實用的Vue開發(fā)技巧

    實用的Vue開發(fā)技巧

    這篇文章主要介紹了7個實用的Vue開發(fā)技巧文。中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,下面我們來一起學習一下吧
    2019-05-05
  • 在IDEA中Debug調(diào)試VUE項目的詳細步驟

    在IDEA中Debug調(diào)試VUE項目的詳細步驟

    idea竟然有一個神功能很多朋友都不是特別清楚,下面小編給大家?guī)砹嗽贗DEA中Debug調(diào)試VUE項目的詳細步驟,感興趣的朋友一起看看吧
    2021-10-10
  • vue3 diff 算法示例

    vue3 diff 算法示例

    這篇文章主要為大家介紹了vue3 diff 的算法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • Vue3在router中使用pinia報錯的簡單解決辦法

    Vue3在router中使用pinia報錯的簡單解決辦法

    這篇文章主要給大家介紹了關(guān)于Vue3在router中使用pinia報錯的簡單解決辦法,什么是pinia,可以理解為狀態(tài)管理工具,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-08-08
  • Vue實現(xiàn)瀏覽器端掃碼功能

    Vue實現(xiàn)瀏覽器端掃碼功能

    本文主要介紹,通過使用基于 vue技術(shù)棧的前端開發(fā)技術(shù),在瀏覽器端調(diào)起攝像頭,并進行掃碼識別功能,對識別到的二維碼進行跳轉(zhuǎn)或其他操作處理,對vue瀏覽器掃碼功能的實現(xiàn)代碼感興趣的朋友一起看看吧
    2021-10-10
  • Vue2實現(xiàn)txt文件在線預覽的代碼示例

    Vue2實現(xiàn)txt文件在線預覽的代碼示例

    txt文件在線預覽不需要下載另外的插件,主要有兩種形式,一種是上傳完成后實現(xiàn)預覽;另一種是后端提供文件下載接口,獲取文件在線地址實現(xiàn)預覽;本文給大家介紹了Vue2實現(xiàn)txt文件在線預覽的代碼示例,需要的朋友可以參考下
    2025-01-01
  • 降低vue-router版本的2種解決方法實例

    降低vue-router版本的2種解決方法實例

    vue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,適合用于構(gòu)建單頁面應用,下面這篇文章主要給大家介紹了關(guān)于降低vue-router版本的2種解決方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07

最新評論