您的位置:首页 > 房产 > 家装 > 苹果开发者官方网站_汕头网站制作全过程_收录网站排名_网站模板图片

苹果开发者官方网站_汕头网站制作全过程_收录网站排名_网站模板图片

2025/1/10 22:04:29 来源:https://blog.csdn.net/DZ_OP/article/details/144009207  浏览:    关键词:苹果开发者官方网站_汕头网站制作全过程_收录网站排名_网站模板图片
苹果开发者官方网站_汕头网站制作全过程_收录网站排名_网站模板图片

Vue 是一款用于构建用户界面的 JavaScript 框架。它基于标准 HTML、CSS 和 JavaScript 构建,并提供了一套声明式的、组件化的编程模型,帮助你高效地开发用户界面。无论是简单还是复杂的界面,Vue 都可以胜任。

在创建我们第一个vue程序之前,我们需要构建一个版本

需要使用到两个模块文件http://vue.esm-brower.js和http://vue.glabal.js

使用script标签导入

 <script src="./vue.global.js"></script>

并且需要下载一个插件live server来作为我们一个虚拟的服务器

一、第一个vue程序

首先来看一下我们的基础代码

 {{ }} 插值表达式, 可以将 Vue 实例中定义的数据在视图中进行渲染

    如: Vue 实例中定义一个 msg 变量, 值为 "Hello world",

    在模板中若使用插值表达式 {{ msg }} 则会被渲染成 "Hello world" 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>第一个Vue程序</title><script src="./vue.global.js"></script>
</head>
<body><div id="app"><p>{{ msg }}</p><p>{{ web.title }}</p><p>{{ web.url }}</p><p>{{ func() }}</p></div><script></script></body>
</html>

每个 Vue 应用都是通过 createApp 函数创建一个新的 应用实例

import { createApp } from 'vue'const app = createApp({/* 根组件选项 */
})

根组件​

我们传入 createApp 的对象实际上是一个组件,每个应用都需要一个“根组件”,其他组件将作为其子组件。

 【第1步】手写一个setup函数, 用于设置组件的响应式"数据"和"方法"等

 创建一个Vue实例,并利用setup函数配置好这个实例里的数据和方法,并将需要用到的数据和方法暴露出来,供HTML调用

    function setup(){// 定义数据let msg = "成功创建第一个Vue应用程序!";const web = Vue.reactive({title: "百度一下,你就知道",url: "www.baidu.com"});// 定义方法(函数)const func = () => {web.title = "广东云浮中医药职业学院";       console.log("方法func被调用");}           // 返回一个对象类型的数据return { msg, web, func}}const set_ =  { setup,   }

【第2步】创建一个 Vue 组件

const vm = Vue.createApp(set_);

【第3步】将 Vue 应用程序挂载(mount) 到 app 元素上

vm.mount("#app");

通过虚拟服务器,点击open with live server来运行,这样就是一个简单的vue程序的实现。

通过控制台可以看到我们调用了两次

二、响应式数据(ref和reactive)

一个网页页面,它是会自动更新的,这种叫做响应式数据,那么我们该如何将非响应式数据变为相响应式数据呢。

ref( ) 接受一个内部值,返回一个ref 对象,这个对象是响应式的、可更改的,且只有一个指向其内部值的属性 .value。

ref() 将传入参数的值包装为一个带 value 属性的 ref 对象。

reactive是Vue3 中的一个函数,它用于将普通对象转换为响应式对象。与ref不同,reactive适用于复杂对象(如对象和数组),而ref仅适用于基本数据类型和对象引用。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>让数据变成响应式</title>
</head><body><div id="app"><p>{{ msg }}</p><p>{{ web.title }}</p><p>{{ web.url }}</p><p>{{number}}</p><button @click="change">点击我更换网址</button></div><script type="module">import {createApp, ref, reactive} from "./vue.esm-browser.js"  //模块化开发方式createApp({setup(){// const number = ref(10);// console.log(typeof number,number);  // number.value = 20;let number = 10;console.log(typeof number,number);  number = 30;const web = reactive({title: "百度一下,你就知道",url: "www.baidu.com"});console.log(typeof web, web);const change = () => {web.url += "-->数据被修改";}// 返回一个对象类型的数据return { msg: "成功创建第一个Vue应用程序!" ,   web,number,change}}}).mount("#app");</script></body>
</html>

我们可以看到使用的ref函数包装msg成为了响应对象,使用了reactive将其做了个点击就修改一次{{web.url}}。

三、事件绑定事件v-on

使用 v-on:事件名= "触发事件" 可以用来绑定标签事件。也可以缩写为@事件名="触发事件" 。事件如:点击,双击,键盘按下等。当触发该事件后,就会调用语句执行。

<!-- v-on:click 表示在 button 元素上监听 click 事件 --><button v-on:click="edit">修改</button> <br><!-- @click 简写形式 --><button @click="add(20, 30)">加法</button> <br>

  常见的事件:

        click: 点击一次;   当鼠标点击,触发事件

        dblclick: 双击;当鼠标双击,触发事件

        focus: 获取焦点;  当得到了光标,触发事件

        blur: 失去焦点;   当失去了光标,触发事件

        mouseover:鼠标移至;  鼠标移至某标签上方,触发事件

        mouserout:鼠标移出; 鼠标移出某标签上方,触发事件

        keyup:键盘按下;  键盘按下,触发事件

接着通过例子来解析一下

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>绑定事件</title>
</head><body><div id="app"><h3>{{ msg }}</h3><h3>{{ web.url }}</h3><h3>{{ web.user }}</h3><h3>{{ sub(100, 20) }}</h3><!-- v-on:click 表示在 button 元素上监听 click 事件 --><button v-on:click="edit">修改</button> <br><!-- @click 简写形式 --><button @click="add(20, 30)">加法</button> <br></div><script type="module">import { createApp, reactive, ref } from './vue.esm-browser.js'createApp({setup() {let msg = "成功启动!!!";const web = reactive({title: "百度",url: "baidu.com",user: 0});const edit = () => {web.url = "www.baidu.com"msg = "云中医" //错误示例 不能直接改变msg的值,因为msg是一个普通变量, 不是响应式数据console.log(`msg修改为: ${msg}`); //从控制台打印信息可以知道确实改变了,但是模板没有响应更新(非响应式数据)    }const add = (a, b) => {web.user += a + b}const sub = (a, b) => {return a - b}return {msg, //普通变量, 非响应式数据, 在模板中普通变量不会自动更新web, //响应式数据edit, //方法add,sub,}}}).mount("#app")</script></body>
</html>

这是没有进行点击前的页面

这是通过v-on绑定后点击的页面

我们通过控制台可以看到,我们通过设置函数通过v-on绑定事件以及加入了点击触发事件,使用了响应式数据让我们数据产生了变化。

不能直接改变msg的值,因为msg是一个普通变量, 不是响应式数据

四、条件渲染指令 v-show 和 v-if

在Vue.js中,v-ifv-show都是用于控制元素显示与隐藏的指令。尽管它们的目的相同,但在实现机制和适用场景上有显著的区别。

 Vue处理v-show变化时,是用display:none实现隐藏的(可以通过F12检查源代码,当点击时,源码会加入display:none) 

Vue处理v-if变化时,是通过删除节点实现隐藏的(可以通过F12检查源代码,当点击时,源码会删除节点) 。当遇到需要频繁显示和隐藏的场景时,不适合使用v-if, 因为频繁增删节点,会导致渲染效率下降 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>节点的条件渲染</title>
</head><body><div id="app"><h3>显示状态: {{ web.show }}</h3><p v-show="web.show">广东云浮中医药职业学院计算机学院v-show</p>   <p v-if="web.show">广东云浮中医药职业学院基础学院v-if</p><button @click="toggle">切换显示状态</button><hr><h3>{{ web.user }}</h3><p v-if="web.user < 100">新网站</p><p v-else-if="web.user >= 100 && web.user < 1000">优秀网站</p><p v-else-if="web.user >= 1000 && web.user < 10000">资深网站</p><p v-else>超级网站</p><button @click="add_user">增加用户</button></div><script type="module">import { createApp, reactive, ref } from './vue.esm-browser.js'createApp({setup() {const web = reactive({   // 响应式数据show: true,user: 500});const toggle = () => {web.show = !web.show;   // 这个布尔变量被切换后,模板中用到的地方会自动更新,进而被v-show捕获}const add_user = () => {web.user += 1000;}return {web,toggle,add_user}}}).mount("#app");</script></body>
</html>

我们可以通过控制台发现v-show和v-on的不同,在使用 v-if 时,还可以通过使用 v-else-if 和 v-else 指令来实现条件分支。

五、遍历指令 v-for

Vue.js 提供的一个用于遍历数组和对象的指令

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>遍历指令</title><style>.textColor{color: red;}</style>
</head><body><div id="app"><!-- 遍历对象的值 --><h4>遍历对象的值。</h4><ul><li v-for="value in data.user">{{ value }}</li></ul><h4>遍历对象的值和索引。 注意:写指令时,先值后索引</h4><ul><li v-for="(value, index) in data.number">{{ index }} : {{ value }}</li></ul><h4>遍历对象的值和键。 注意:写指令时,先值后键</h4><ul><li v-for="(value, key) in data.user">{{ key }} : {{ value }}</li></ul><h4>遍历对象的值,键和索引。 注意:写指令时,先值再键后索引</h4><ul><li v-for="(value, key, index) in data.user">{{ index }} : {{ key }} : {{ value }}</li></ul><h4>指令嵌套: 先用v-for指令遍历对象,然后展示符合v-if条件的节点</h4><ul><template v-for="(value, key, index) in data.user"><li v-if="index == 1">  {{ index }} : {{ key }} : {{ value }}</li>           </template></ul></div><script type="module">import { createApp, reactive } from './vue.esm-browser.js'createApp({setup() {const data = reactive({//数组number: ["十",  "十一",  "十二"], //对象user: { name: "李雷",   gender: "女" }});return {data}}}).mount("#app")</script></body>
</html>

 遍历对象的值和索引。 注意:写指令时,先值后索引

 遍历对象的值和键。 注意:写指令时,先值后键

遍历对象的值,键和索引。 注意:写指令时,先值再键后索引

指令嵌套: 先用v-for指令遍历对象,然后展示符合v-if条件的节点

<template> 标签可以用来包装多个元素或者多行代码, 不会在页面中渲染

六、节点的动态属性 v-bind(单向绑定)

v-bind 指令用于动态绑定 HTML 属性和组件属性。 通过 v-bind 指令,可以将 Vue 实例中的数据动态地绑定到 HTML 元素的属性上,从而实现数据的动态更新和响应式渲染。 v-bind 指令有一个常用的简写形式,即使用 : 前缀。 例如, v-bind:href 可以简写为 :href。

<body><div id="app"><h3>  iuput标签动态属性绑定    v-bind:value </h3><input type="text" v-bind:value="web.str"></div><script type="module">import { createApp, reactive } from './vue.esm-browser.js'createApp({setup() {const web = reactive({str: "w",img: "./img_src/logo0.png",fontStatus: false})const change = () => {web.str += "w";web.img=`./img_src/logo1.png`;web.fontStatus = !web.fontStatus;}return {web,change}}}).mount("#app")</script>

我们可以看到通过v-bind单向绑定后,点击修改按钮,input框里面会被添加一个w(代码里写了个函“+w”)

img标签以及内嵌的css样式也可以绑定

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>节点的动态属性(单向绑定)</title><style>.textColor{color: red;}</style>
</head><body><div id="app"><h3>  iuput标签动态属性绑定    v-bind:value </h3><input type="text" v-bind:value="web.str"><h3>  iuput标签动态属性绑定(简写形式)   :str </h3><input type="text" :value="web.str"><h3>  img标签动态属性绑定(简写形式)    :src </h3><img :src="web.img"><h3>  b标签动态属性绑定(简写形式)   :class</h3><h4>  注:通过布尔值控制某个类名是否存在,进而控制对应的CSS样式是否被选中生效</h4><b :class="{textColor:web.fontStatus}">广东云浮中医药职业学院</b><br><button @click="change">修改</button></div><script type="module">import { createApp, reactive } from './vue.esm-browser.js'createApp({setup() {const web = reactive({str: "w",img: "./img_src/logo0.png",fontStatus: false})const change = () => {web.str += "w";web.img=`./img_src/logo1.png`;web.fontStatus = !web.fontStatus;}return {web,change}}}).mount("#app")</script></body>
</html>

没点击前:

点击后:

可以看到直接将图片路径被修改以及css样式是直接给添加上去

在实际开发中,v-bind 指令广泛应用于动态绑定样式、动态绑定类名和动态绑定属性等场景。通过深入理解 v-bind 指令的作用和使用方法,开发者可以更好地应用 Vue.js 来构建高效、灵活的前端应用。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com