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();
    },
},
相关推荐
2401_873479401 小时前
如何利用IP查询定位识别电商刷单?4个关键指标+工具配置方案
开发语言·tcp/ip·php
Mh1 小时前
鼠标跟随倾斜动效
前端·css·vue.js
我爱cope2 小时前
【从0开始学设计模式-10| 装饰模式】
java·开发语言·设计模式
菜鸟学Python2 小时前
Python生态在悄悄改变:FastAPI全面反超,Django和Flask还行吗?
开发语言·python·django·flask·fastapi
浪浪小洋3 小时前
c++ qt课设定制
开发语言·c++
charlie1145141913 小时前
嵌入式C++工程实践第16篇:第四次重构 —— LED模板,从通用GPIO到专用抽象
c语言·开发语言·c++·驱动开发·嵌入式硬件·重构
故事和你913 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
幺风4 小时前
Claude Code 源码分析 — Tool/MCP/Skill 可扩展工具系统
前端·javascript·ai编程
程序猿编码4 小时前
给你的网络流量穿件“隐形衣“:手把手教你用对称加密打造透明安全隧道
linux·开发语言·网络·安全·linux内核
ID_180079054734 小时前
淘宝 API 上货 / 商品搬家 业务场景实现 + JSON 返回示例
前端·javascript·json