2.4 第一个Vue.js程序
接下来让我们动手感受一下Vue.js,构建一个“水果介绍”的简单页面。和许多JavaScript应用一样,首先从网页中需要展示的数据开始。使用Vue的起步非常简单,安装Vue库,使用Vue.createApp创建一个应用程序实例。Vue在创建组件实例时会调用data()函数,该函数将返回数据对象,最后通过mount()方法在指定的DOM元素上装载应用程序实例的根组件,从而实现数据的双向绑定。
【例2.1】 编写“水果介绍”页面(源代码\ch02\2.1.html)。
这里使用v-bind指令绑定IMG的src属性,使用{{}}语法(插值语法)显示标题<h2>的内容。
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div id="app"> <div><img v-bind:src="url" width="450"></div> <h2>{{ explain }}</h2> </div> <!--引入Vue文件--> <script src="https://unpkg.com/vue@next"></script> <script> //创建一个应用程序实例 const vm= Vue.createApp({ //该函数返回数据对象 data(){ return{ url:'1.jpg', explain:'苹果是蔷薇科苹果亚科苹果属植物,其营养价值很高。', } } //在指定的DOM元素上装载应用程序实例的根组件 }).mount('#app'); </script> </body> </html>
程序运行效果如图2-23所示。
图2-23 “水果介绍”页面效果
至此,就成功创建了第一个Vue应用,这看起来跟渲染一个字符串模板非常类似,但是Vue在背后做了大量工作。可以通过浏览器的JavaScript控制台来验证,也可以使用vue-devtools调试工具来验证。
例如,在浏览器上按F12键,打开控制台并切换到Console选项,修改vm.explain="我最爱吃的就是苹果!",按回车键后,可以发现页面的内容也发生了改变,效果如图2-24所示。
图2-24 在控制台上修改后的效果
使用vue-devtools工具调试,打开浏览器的控制台,选择Vue选项,单击左侧的<Root>,同样修改vm.explain="苹果中营养成分可溶性大,容易被人体吸收!",单击“保存”按钮,可以发现页面的内容同样也发生了改变,效果如图2-25所示。
图2-25 vue-devtools调试效果
出现上面这样的效果,是因为Vue是响应式的。也就是说当数据变更时,Vue会自动更新所有网页中用到它的地方。除了小程序中使用的字符串类型外,Vue对其他类型的数据也是响应的。
特别说明:在之后的章节中,示例不再提供完整的代码,而是根据上下文,将HTML部分与JavaScript部分单独展示,省略了<head>、<body>等标签以及Vue.js的加载等,读者可根据上面示例的代码结构来组织代码。