vue加载后不变原理

一、随机

在开发阶段,如下

javascript 复制代码
export const mock = {
 moth: Math.ceil(Math.random() * 10)
}

使用mock

javascript 复制代码
import { mock } from "@/help/index.js";

getDate() {
 console.log(mock)
}

发现执行getDate()得到的mock一直是加载初次的随机数,并未随机,这是因为加载中已经执行mock数据已经固定,再使用就不能改变,只能用初次加载的数据,

可见vue执行js后,如果非方法会执行一次,后面直接使用,并不执行js了,但是需要的是每次使用执行其随机的数,改变其数据

解决方案,改mock为方法去调用,就每次执行方法得到最新随机数,和接口请求一个原理

javascript 复制代码
export const mock = () => {
  return {
     moth: Math.ceil(Math.random() * 10)
    }
}

//调用
import { mock } from "@/help/index.js";
getDate() {
 console.log(mock())
}

二、provide

在开发阶段,如下

javascript 复制代码
provide() {
   return {
     getMockList: this.getMock,
   };
},
methods: {
    set() {
      this.getMock = Math.ceil(Math.random() * 10)
    }
}

执行set()后子组件通过inject调用

javascript 复制代码
inject: ["getDataInit"],
mounted() {
    console.log(this.getDataInit)
},

发下getDataInit并未变

可见vue执行provide后,如果非方法会执行一次,后面直接使用,并不执行provide了,但是需要的是每次使用执行其随机的数,改变其数据

解决方案,改provide为方法去调用,就每次执行方法得到最新随机数,子组件需要通过computed接受或者调用方法

javascript 复制代码
provide() {
    return {
      getMockList: () => this.getMock,
    };
 },

//子组件通过computed接受或者直接调用方法
computed: {
    getMock() {
      return this.getMockList();
    },
},
相关推荐
qq_479875434 分钟前
X-Macros(3)
java·开发语言
列逍20 分钟前
深入理解 C++ 异常:从概念到实战的全面解析
开发语言·c++
java1234_小锋25 分钟前
简述Mybatis的插件运行原理?
java·开发语言·mybatis
charlie11451419140 分钟前
勇闯前后端Week2:后端基础——HTTP与REST
开发语言·网络·笔记·网络协议·学习·http
一颗烂土豆44 分钟前
告别 Vue 多分辨率适配烦恼:vfit 让元素定位 “丝滑” 跨设备
前端·vue.js
萌狼蓝天1 小时前
[Vue]性能优化:动态首行与动态列的匹配,表格数据格式处理性能优化
前端·javascript·vue.js·性能优化·ecmascript
一 乐1 小时前
宠物管理宠物医院管理|基于Java+vue的宠物医院管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·宠物
一 乐1 小时前
学习辅导系统|数学辅导小程序|基于java+小程序的数学辅导小程序设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·学习·小程序
福尔摩斯张1 小时前
二维数组详解:定义、初始化与实战
linux·开发语言·数据结构·c++·算法·排序算法