溫馨提示×

溫馨提示×

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

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

vue3使用reactive賦值后頁面不改變怎么解決

發(fā)布時間:2023-04-27 10:45:43 來源:億速云 閱讀:156 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了vue3使用reactive賦值后頁面不改變怎么解決的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇vue3使用reactive賦值后頁面不改變怎么解決文章都會有所收獲,下面我們一起來看看吧。

    場景原因

    我們需要在vue3中使用服務(wù)器的數(shù)據(jù)渲染到頁面上,我使用的是reactive生成的響應(yīng)式數(shù)據(jù)屬性,但是在掛載后請求的數(shù)據(jù)并沒有渲染顯示到頁面上。

    技術(shù):vue3 、 element-ui-plus

    一、例子

    home.vue

    <template>
      <div class="common-layout">
        <el-menu @select="changeMenu" :collapse="isCollapse" active-text-color="#409eff" background-color="#333744"
          class="el-menu-vertical-demo" default-active="2" text-color="#fff" :unique-opened="true">
          <el-sub-menu :index="item.path" v-for="(item) in parmar.menus" :key="item.id">
            <template #title>
              <el-icon>
                <List />
              </el-icon>
              <span>{{ item.authName }}</span>
            </template>
            <el-menu-item :index="item2.path" v-for="(item2) in item.children" :key="item2.id">
              <el-icon>
                <Menu />
              </el-icon>
              {{ item2.authName }}
            </el-menu-item>
          </el-sub-menu>
        </el-menu>
      </div>
    </template>
    <script setup>
    // 引入模塊
    import { reactive, onMounted } from 'vue'
    import { useRouter } from 'vue-router'
    import http from '@/utils/request'
    const router = useRouter();
    let menusList = reactive([
    ]);
    onMounted(() => {
      getData()
    })
    const getData = async () => {
      let { data } = await http.get('/menus');
      // 這里直接賦值,會導(dǎo)致menusList失去響應(yīng)式了
      menusList = data.data;
      console.log(menusList);
    }
    const changeMenu = (key) => {
      router.push('/home/' + key)
    }
    </script>
    <style lang="less" scoped>
    .common-layout {
      height: 100vh;
      box-sizing: border-box;
      position: relative;
      overflow: hidden;
      /deep/.el-menu--vertical {
        margin: 0;
        border-right: none !important;
        overflow-x: hidden;
        height: calc(100vh - 100px);
        user-select: none;
      }
      .el-menu-vertical-demo:not(.el-menu--collapse) {
        width: 200px;
        min-height: 400px;
      }
    }
    </style>

    vue3使用reactive賦值后頁面不改變怎么解決

    我們通過直接賦值,可以看出數(shù)據(jù)變?yōu)槠胀ǖ臄?shù)據(jù)了,并不是響應(yīng)式的。

    二、解決方法

    1、使用ref存儲響應(yīng)式數(shù)據(jù)

    代碼如下:

    <script setup>
    // 引入模塊
    import { ref, reactive, onMounted } from 'vue'
    import http from '@/utils/request'
    let menusList = ref([
    ]);
    onMounted(() => {
      getData()
    })
    const getData = async () => {
      let { data } = await http.get('/menus');
      // 這里直接賦值value,在頁面上直接使用menusList即可!
      menusList.value = data.data;
    }
    </script>

    vue3使用reactive賦值后頁面不改變怎么解決

    可以看出打印出的數(shù)據(jù)是經(jīng)過ref劫持的數(shù)據(jù),是響應(yīng)式的。

    2、在reactive中使用對象包裹要改變的數(shù)據(jù)

    代碼如下:

    <script setup>
    // 引入模塊
    import { reactive, onMounted } from 'vue'
    import http from '@/utils/request'
    let parmar = reactive({
      menus: [
      ]
    });
    onMounted(() => {
      getData()
    })
    const getData = async () => {
      let { data } = await http.get('/menus');
      // 這里直接賦值對象里面的數(shù)據(jù),就不會造成把響應(yīng)式替換掉的情況了,直接在頁面上通過parmar.menus使用數(shù)據(jù)!
      parmar.menus = data.data;
      console.log( parmar);
    }
    </script>

    vue3使用reactive賦值后頁面不改變怎么解決

    使用這種方式,數(shù)據(jù)也是響應(yīng)式的。

    3、for of循環(huán)push到reactive數(shù)據(jù)中,不破壞數(shù)據(jù)結(jié)構(gòu)

    代碼如下:

    <script setup>
    // 引入模塊
    import { reactive, onMounted } from 'vue'
    import http from '@/utils/request'
    let menusList = reactive([])
    onMounted(() => {
      getData()
    })
    const getData = async () => {
      let { data } = await http.get('/menus');
      for (let i of data.data){
        menusList.push(i);
      }
      console.log(menusList);
    }
    </script>

    vue3使用reactive賦值后頁面不改變怎么解決

    關(guān)于“vue3使用reactive賦值后頁面不改變怎么解決”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“vue3使用reactive賦值后頁面不改變怎么解決”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

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

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

    AI