首页 > web前端 > Vue.js > 正文

vue3使用reactive赋值后页面不改变怎么解决

WBOY
发布: 2023-05-15 14:22:21
转载
4091人浏览过

    场景原因

    我们需要在vue3中使用服务器的数据渲染到页面上,我使用的是reactive生成的响应式数据属性,但是在挂载后请求的数据并没有渲染显示到页面上。

    技术:vue3element-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');
      // 这里直接赋值,会导致menusList失去响应式了
      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赋值后页面不改变怎么解决

    我们通过直接赋值,可以看出数据变为普通的数据了,并不是响应式的。

    二、解决方法

    1、使用ref存储响应式数据

    代码如下:

    图改改
    图改改

    在线修改图片文字

    图改改 455
    查看详情 图改改

    立即学习前端免费学习笔记(深入)”;

    <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赋值后页面不改变怎么解决

    可以看出打印出的数据是经过ref劫持的数据,是响应式的。

    2、在reactive中使用对象包裹要改变的数据

    代码如下:

    立即学习前端免费学习笔记(深入)”;

    <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');
      // 这里直接赋值对象里面的数据,就不会造成把响应式替换掉的情况了,直接在页面上通过parmar.menus使用数据!
      parmar.menus = data.data;
      console.log( parmar);
    }
    </script>
    登录后复制

    vue3使用reactive赋值后页面不改变怎么解决

    使用这种方式,数据也是响应式的。

    3、for of循环push到reactive数据中,不破坏数据结构

    代码如下:

    立即学习前端免费学习笔记(深入)”;

    <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赋值后页面不改变怎么解决

    以上就是vue3使用reactive赋值后页面不改变怎么解决的详细内容,更多请关注php中文网其它相关文章!

    相关标签:
    最佳 Windows 性能的顶级免费优化软件
    最佳 Windows 性能的顶级免费优化软件

    每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

    下载
    来源:亿速云网
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    最新问题
    开源免费商场系统广告
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送
    PHP中文网APP
    随时随地碎片化学习

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号