解决Vue再浏览器的控制台中更新属性不生效

解决Vue再浏览器上更新属性不生效

问题发现

最近在学习Vue2,再介绍-声明式渲染一文中,示例代码如下:

html 复制代码
<div id="app">
  {{ message }}
</div>
javascript 复制代码
var app = new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue!'
  }
})

创建了第一个 Vue 应用,现在数据和 DOM 已经被建立了关联,所有东西都是响应式的。在看到我们要怎么确认呢?打开你的浏览器的 JavaScript 控制台 (就在这个页面打开),并修改 app.message 的值,你将看到上例相应地更新

然后我就尝试再浏览器的控制台中修改对应属性值,期望能看到实时更新显示,执行结果如图所示:

并未达到预期效果,本地示例代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="app">
        {{message}}
    </div>
    <script type="module">
        import Vue from 'https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.esm.browser.js'
        var app = new Vue({
            el: "#app",
            data: {
                "message": "hello, world"
            }
        })
    </script>
</body>
</html>

但是在代码里面执行却可以,示例代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="app">
        {{message}}
    </div>
    <script>
		import Vue from 'https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.esm.browser.js'
        var app = new Vue({
            el: "#app",
            data: {
                "message": "hello, world"
            }
        })
        app.message="hello, vue"
    </script>
</body>
</html>

执行结果如图所示:

问题解决

"出师未捷身先死",正当我百思不得其解的时候,切换CDN版本,示例代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="app">
    	{{message}}
    </div>
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.js"></script>
    <script>
        var app = new Vue({
            el: "#app",
            data: {
                "message": "hello, world"
            }
        })
    </script>
</body>
</html>

竟然成功了,执行结果如图所示:

我们回来看之前的问题:为什么原 ES Modules 在浏览器中无法使用?先了解下什么是 ES Modules

ES ModulesECMAScript Modules )是 JavaScript 官方的模块化标准,自 ES6ES2015 )起正式引入。它为 JavaScript 提供了标准化的模块导入 / 导出机制,解决了传统 JavaScript 在大型应用中依赖管理和代码组织的痛点,模块具有独立的私有作用域,内部变量不会污染全局作用域。

现代浏览器(Chrome 61+、Firefox 60+、Safari 10.1+)直接支持 ES Modules,无需额外编译。

ES 模块中,var声明的变量会被限制在模块内部

到这里我们也知道为什么再浏览器中无法使用了,如果为了达到演示效果,可以将实例挂载到window对象,示例代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="app">
        {{message}}
    </div>
    <script type="module">
        import Vue from 'https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.esm.browser.js'
        // 将实例挂载到window对象,便于控制台访问
        window.app = new Vue({
            el: "#app",
            data: {
                "message": "hello, world"
            }
        })
    </script>
</body>
</html>

执行结果如图所示:

通过挂载到window对象,将对象设置(暴露)为全局作用域,这样便可在浏览器实时响应了。

至于为什么CDN引入的脚本,在浏览器中为什么可以直接使用?官网中解释如下:

直接下载并用 <script> 标签引入,Vue 会被注册为一个全局变量。

CDN 引入的传统脚本中,var会暴露到全局作用域,这是为了兼容历史设计和全局库的使用场景。

既然这样,不妨大胆想象,是不是普通的脚本也可以再浏览器的控制台中访问,是不是也可以进行实时响应呢,实践出真知,示例代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="app"></div>
    <script>
        var a = 100;
        document.getElementById("app").innerHTML = a;
    </script>
</body>
</html>

执行结果如图所示:

好像和预期的并不一样,这是为什么呢?

通常是由 JavaScript 的变量赋值机制、作用域规则或操作逻辑导致的。普通脚本中的变量不会自动响应外部变化,需通过代码主动修改(如定时器、事件监听)。修改app.message = '新值'后,视图会自动更新,主要依赖于其响应式系统数据劫持机制 。这是 Vue 的核心特性之一,与原生 JavaScript 的变量行为有本质区别。

相关推荐
MiyueFE36 分钟前
为什么 JavaScript 中 Map 比 Object 更好
javascript
bo521001 小时前
vue3单元测试-初步了解
vue.js·单元测试
極光未晚1 小时前
JavaScript 中 this 指向的全面解析
javascript
99乘法口诀万物皆可变1 小时前
C#设计模式之AbstractFactory_抽象工厂_对象创建新模式-练习制作PANL(一)
服务器·javascript·c#·html
@PHARAOH2 小时前
WHAT - React Native 开发 App 从 0 到上线全流程周期
javascript·react native·react.js
集成显卡2 小时前
图片压缩工具 | Electron应用配合 commander 提供命令行调用功能
前端·javascript·electron·人机交互·命令行·cmd
我是来人间凑数的2 小时前
electron 嵌入web网页的三种方式
前端·javascript·electron
天上掉下来个程小白2 小时前
Apache ECharts-01.介绍
前端·javascript·spring boot·apache·苍穹外卖
夜空孤狼啸2 小时前
前端常用拖拽组件库(vue3、react、vue2)
前端·javascript·react.js·typescript·前端框架·vue3
嘗_2 小时前
暑期前端训练day1
前端·javascript·八股文·手撕代码