Vue - 4( 8000 字 Vue 入门级教程)

一: Vue 初阶

1.1 关于不同版本的 Vue

Vue.js 有不同版本,如 vue.jsvue.runtime.xxx.js,这些版本主要针对不同的使用场景和需求进行了优化,区别主要体现在以下几个方面:

  1. 完整版 vs 运行时版

    • vue.js(完整版):这是包含编译器的完整构建版本。它包括 Vue 的 template 模板编译器,可以将 Vue 模板直接编译成渲染函数。因此,它适用于独立运行的 Vue.js 项目或通过 <script> 引入的方式直接使用。
    • vue.runtime.xxx.js(运行时版):这是不包含模板编译器的版本,体积更小。它假设你使用了其他构建步骤来预编译模板,或者通过 Vue 的单文件组件 (SFC) 来开发。这种版本需要配合使用 webpack 或其他构建工具进行构建。
  2. 适用场景

    • 完整版适用于传统的 Vue.js 项目,特别是对于通过 <script> 标签直接引入 Vue 的项目。它包含了模板编译器,因此可以接受字符串模板,而不需要预编译。
    • 运行时版更适合基于构建系统(如 Vue CLI、webpack 等)的项目,其中模板是预编译的,因此不需要 Vue 自带的编译器,可以减小项目体积并提高运行效率。
  3. 为什么要分这么多版本

    • 灵活性和体积优化:Vue.js 为了提供更多的灵活性和优化体积,将模板编译器与运行时分离。对于大型项目或需要性能优化的项目,可以选择运行时版本,并预先编译模板,以减小包大小和提高加载速度。
    • 开发体验:对于单文件组件(SFC)的开发,使用运行时版本可以更好地配合现代构建工具(如 webpack)进行开发和部署,更符合当前前端开发的最佳实践。

在这里插入图片描述

1.2 asserts 文件夹

在前端项目中,asserts 文件夹通常用来存放静态资源文件,些资源文件包括但不限于:

  1. 图像文件:如 .jpg, .png, .gif 等格式的图片文件,用于网站的图像展示、背景等。
  2. 样式表文件:如 .css, .scss, .less 等格式的样式表文件,用于定义网站的样式和布局。
  3. 字体文件:如 .ttf, .woff, .woff2 等格式的字体文件,用于网站的文字排版。
  4. JavaScript 文件:如 .js 格式的 JavaScript 脚本文件,用于网站的交互逻辑和功能实现。
  5. 视频文件:如 .mp4, .avi, .mov 等格式的视频文件,用于网站的视频展示或背景视频。
  6. 音频文件:如 .mp3, .ogg, .wav 等格式的音频文件,用于网站的音频播放或背景音乐。
  7. 其他静态文件:如 .html, .xml, .json 等格式的文件,用于网站的其他静态内容。

这些静态资源文件通常在开发中需要被引用和加载到网页中,因此将它们放在 asserts 文件夹中,便于管理和组织。

1.3 components 文件夹

在前端开发中,components 文件夹通常用来存放 Vue.js 应用中的组件文件,将所有组件集中存放在一个文件夹下,可以使得项目结构更加清晰,开发者可以快速找到需要的组件文件。

除了常见的 App.vue 组件外,components 文件夹中可能还会包含其他各种功能性和业务相关的组件,例如:

  • Header.vue:顶部导航栏组件。
  • Footer.vue:底部版权信息组件。
  • Sidebar.vue:侧边栏组件。
  • Button.vue:自定义按钮组件。
  • Modal.vue:弹窗组件。
  • 等等。

每个组件都有其特定的功能和作用,通过组合这些组件,可以构建出复杂的用户界面。而 App.vue 则是 Vue.js 应用的根组件,负责整个应用的布局和路由管理,通常会包含其他子组件来组成完整的页面结构。

1.4 render 函数

render 函数有模板解析器,可以用来渲染虚拟 DOM 的函数。通过 render 函数,我们可以直接利用 JavaScript 来描述组件的 UI 布局和结构,而不是依赖于模板语法。

下面是关于render 函数的详细解析:

参数:
render 函数接受一个参数,通常命名为 h,这个参数实际上是 createElement 函数的别名,用于创建 VNode(虚拟节点)。

注意点:

  • 返回值render 函数必须返回一个 VNode,用于描述组件的 UI 结构。
  • 单一根节点render 函数中返回的 VNode 必须是一个单一的根节点,即只能返回一个 VNode。
  • 箭头函数:通常 render 函数使用箭头函数来定义,以确保函数内部的 this 指向正确。

createElement 的用法:

createElement 函数用于创建 VNode(虚拟节点),描述组件的 UI 结构。它接受三个参数:

  1. 参数1(必填):标签名、组件选项或者一个返回组件选项的函数。
  2. 参数2(可选):一个包含组件属性和数据的对象,也可以是 null
  3. 参数3(可选):子节点,可以是一个数组或者一个字符串。

createElement 的用法通常如下:

h(tag, data, children)

其中:

  • tag:可以是 HTML 标签名,也可以是组件选项。
  • data:是一个对象,包含了组件的属性和数据。
  • children:是一个数组,包含了组件的子节点。

例如,一个简单的 createElement 的用法如下:

h('div', { class: 'container' }, [h('h1', 'Hello, Vue!'),h('p', 'This is a paragraph.')
])

这段代码会创建一个 <div> 元素,其类名为 container,包含一个 <h1> 元素和一个 <p> 元素作为子节点。

render 函数简写过程:

//完整版
render(createdElment){return createdElment('h1','你好啊')}//第一步render:(createdElment)=>{return createdElment('h1','你好啊')}//第二步render:createdElment=> createdElment('h1','你好啊')//第三步render:h=> h('h1','你好啊')

1.5 ref 属性

ref 是 Vue.js 中用来在模板中获取对 DOM 元素或组件实例的引用的属性。它的作用十分重要,能够让我们在 Vue 组件中直接操作 DOM,或者获取到子组件的实例,从而实现一些特定的逻辑或操作。

下面我来详细解释 ref 的作用:

作用:

  1. 获取 DOM 元素引用:通过在模板中使用 ref,可以获取到对应 DOM 元素的引用,从而在 Vue 组件中直接操作该 DOM 元素。

  2. 获取组件实例引用:除了获取 DOM 元素的引用,ref 还可以获取到子组件的实例引用,使得我们可以直接调用子组件的方法或访问其属性。

  3. 动态引用ref 属性可以动态地绑定到数据属性上,使得我们可以根据条件或状态动态地获取对应的 DOM 元素或组件实例。

代码示例:

获取 DOM 元素引用:

<template><div><button ref="myButton" @click="handleClick">Click me</button></div>
</template><script>
export default {methods: {handleClick() {// 使用 $refs 来获取 DOM 元素引用,并直接操作该 DOM 元素this.$refs.myButton.innerText = 'Button Clicked';}}
}
</script>

在这个示例中,ref="myButton" 将按钮元素的引用保存在了 myButton 中,然后在 handleClick 方法中,通过 this.$refs.myButton 获取到按钮元素的引用,并修改了按钮的文本内容。

获取子组件实例引用:

<template><div><!-- 使用 ref 获取子组件实例 --><child-component ref="myChild"></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},mounted() {// 使用 $refs 获取子组件实例,并调用子组件的方法this.$refs.myChild.sayHello();}
}
</script>

在这个示例中,通过 ref="myChild" 获取了子组件 ChildComponent 的实例引用,然后在 mounted 钩子函数中,通过 this.$refs.myChild 获取到了子组件的实例,并调用了子组件的 sayHello 方法。

动态引用:

<template><div><div v-if="showRef"><input ref="inputField" type="text" placeholder="Enter something" /></div><button @click="toggleRef">Toggle Ref</button></div>
</template><script>
export default {data() {return {showRef: true};},methods: {toggleRef() {// 动态修改 showRef 的值,控制是否显示 refthis.showRef = !this.showRef;// 在输入框显示时,获取输入框的引用并聚焦if (this.showRef) {this.$refs.inputField.focus();}}}
}
</script>

在这个示例中,通过 v-if 控制了一个输入框的显示与隐藏,当点击按钮时,通过 toggleRef 方法动态地切换输入框的显示状态。当输入框显示时,使用 this.$refs.inputField.focus() 获取输入框的引用并使其获得焦点。

1.6 props 配置

在 Vue.js 中,props 是用于父组件向子组件传递数据的一种机制。通过在子组件上声明 props,可以将父组件中的数据传递给子组件,在子组件内部可以像访问本地数据一样使用这些 props。这种数据流的方式使得组件之间的通信更加灵活和维护。

下面我来详细解释 props 的用途以及如何在 Vue.js 中使用:

用途:

  1. 传递数据:最常见的用途是在父组件中将数据传递给子组件,子组件可以通过 props 接收这些数据并在内部使用。
  2. 向子组件传递事件:除了数据之外,父组件还可以通过props` 向子组件传递方法,以便子组件可以调用这些方法来实现特定的行为或逻辑。

代码示例:

1. 父组件向子组件传递数据:

<!-- ParentComponent.vue(父组件) -->
<template><div><!-- 在子组件上使用 props将 message 数据传递给子组件 --><ChildComponent :message="messageFromParent"  </div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},data() {return {messageFromParent: 'Hello from parent component'};}
}
</script>
<!-- ChildComponent.vue(子组件) -->
<template><div><!-- 在子组件中使用 props 接收来自父组件的数据 --><p>{{ message }}</p></div>
</template><script>
export default {props: {// 声明 props,接收来自父组件的 message 数据message: String}
}
</script>

在这个示例中,父组件 ParentComponent 中的 messageFromParent 数据通过 message props 传递给了子组件 ChildComponent,子组件内部使用 props 来接收父组件传递的数据,并渲染到页面上。

父组件向子组件传递方法:

<!-- ParentComponent.vue(父组件) -->
<template><div><!-- 在子组件上使用 props,将父组件的方法传递给子组件 --><ChildComponent :handleClick="handleClickFromParent" /></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},methods: {handleClickFromParent() {console.log('Button clicked in parent component');}}
}
</script>
<!-- ChildComponent.vue(子组件) -->
<template><div><!-- 在子组件中使用 props 接收来自父组件的方法 --><button @click="handleClick">Click me</button></div>
</template><script>
export default {props: {// 声明 props,接收来自父组件的方法handleClick: Function},methods: {handleClick() {// 在子组件中调用父组件传递的方法this.handleClick();}}
}
</script>

在这个示例中,父组件 ParentComponent 中的 handleClickFromParent 方法通过 handleClick props 传递给了子组件 ChildComponent,子组件内部使用 props 来接收父组件传递的方法,并在按钮点击时调用该方法。

1.6.1 子组件向父组件传递数据

在 Vue.js 中,通过 props 和父组件预先定义的方法,可以使子组件向父组件传递数据。这个过程涉及了子组件调用父组件传递的函数,并将数据作为参数传递回父组件的过程。

实现子组件向父组件传递数据的步骤:

  1. 在父组件中定义方法并将其传递给子组件:首先,在父组件中定义一个方法,并将这个方法通过 props 传递给子组件。

  2. 子组件调用父组件传递的方法:在子组件中调用从父组件接收到的方法,并传递数据作为参数。

代码示例:

父组件定义方法并传递给子组件:

<!-- ParentComponent.vue(父组件) -->
<template><div><!-- 将父组件的方法传递给子组件 --><ChildComponent :sendDataToParent="sendDataToParent" /></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},methods: {// 定义父组件的方法sendDataToParent(data) {console.log('Data received in parent:', data);// 这里可以对数据进行处理或进一步操作}}
}
</script>

子组件调用父组件传递的方法并传递数据:

<!-- ChildComponent.vue(子组件) -->
<template><div><button @click="sendDataToParent">Send Data to Parent</button></div>
</template><script>
export default {props: {// 声明接收父组件传递的方法sendDataToParent: Function},methods: {sendDataToParent() {const data = 'Data from child component';// 调用父组件传递过来的方法,并传递数据this.sendDataToParent(data);}}
}
</script>

在这个示例中,父组件 ParentComponent 定义了一个名为 sendDataToParent 的方法,并将这个方法通过 props 传递给子组件 ChildComponent。在子组件中,当按钮被点击时,sendDataToParent 方法会被调用,并向父组件传递数据 'Data from child component'

这样,子组件就可以通过调用父组件预先定义的方法,向父组件传递数据。父组件可以在接收到数据后执行相应的逻辑或处理操作,实现了子组件向父组件的数据传递。

1.7 mixin 混入

在 Vue.js 中,mixin 是一种重用组件选项的一种方式。它允许我们定义一些可复用的组件选项,并在多个组件中共享这些选项。

mixin 可以包含组件选项,如数据、计算属性、方法、生命周期钩子等,通过混入 mixin,这些选项会被合并到组件的选项中,从而实现了代码的复用和组件的扩展。

下面我来详细解释 mixin 的用途以及如何在 Vue.js 中使用:

用途:

  1. 代码复用mixin 允许我们将一些通用的逻辑或功能抽离出来,定义在 mixin 中,然后在多个组件中重用这些逻辑或功能,避免代码重复,提高代码的可维护性和可读性。

  2. 逻辑组织:通过 mixin,我们可以将组件选项按照功能进行拆分和组织,使得代码结构更加清晰和易于管理。

  3. 动态修改组件选项:在一些特定场景下,我们可以动态地为组件添加或修改选项,这使得 mixin 具有一定的灵活性,可以根据需要动态地调整组件的行为。

代码示例:

创建一个 mixin:

// exampleMixin.js
export const exampleMixin = {data() {return {count: 0};},methods: {increment() {this.count++;},decrement() {this.count--;}}
};

在这个示例中,我们创建了一个名为 exampleMixin 的 mixin,其中包含了一个名为 count 的数据属性和两个方法 incrementdecrement

在组件中使用 mixin:

<template><div><p>Count: {{ count }}</p><button @click="increment">Increment</button><button @click="decrement">Decrement</button></div>
</template><script>
import { exampleMixin } from './exampleMixin.js';export default {mixins: [exampleMixin], // 使用 mixin
};
</script>

在这个示例中,我们在一个 Vue 组件中使用了 exampleMixin,通过在组件选项中的 mixins 数组中添加 exampleMixin,该 mixin 中的数据和方法会被合并到组件的选项中,从而实现了代码的复用。

动态修改组件选项:

// exampleMixin.js
export const exampleMixin = {data() {return {message: 'Hello from mixin'};},created() {console.log('Mixin created');}
};// 在组件中动态添加 mixin
Vue.mixin(exampleMixin);

在这个示例中,我们在 exampleMixin 中定义了一个 message 数据属性和一个 created 生命周期钩子。然后通过 Vue.mixin 方法将 exampleMixin 动态地添加到全局的 Vue 实例中,这样在任何组件中都可以使用 exampleMixin 中的选项了。

1.8 scoped 样式

在 Vue.js 中,scoped 是一个用于样式作用域控制的特殊属性,它可以限定样式只在当前组件中生效,而不会影响到其他组件。这种机制可以避免全局样式污染和样式冲突,使得组件化开发更加可靠和可维护。

下面我来详细解释 scoped 的用途以及如何在 Vue.js 中使用:

用途:

  1. 避免样式污染:通过 scoped 属性,可以确保当前组件中的样式只作用于当前组件,不会影响到全局的样式,避免了样式污染问题。

  2. 组件化开发scoped 样式使得组件更加独立和可移植,组件可以被放置在任何上下文中而不会产生样式冲突,从而实现了更高程度的组件化开发。

  3. 提高样式可维护性:将样式与组件紧密绑定在一起,可以使得样式与组件的关系更加清晰,提高了样式的可维护性和可读性。

代码示例:

使用 scoped 属性定义样式:

<template><div class="example"><p>This is a scoped example component.</p></div>
</template><script>
export default {name: 'ExampleComponent'
}
</script><style scoped>
.example {background-color: #f0f0f0;padding: 20px;
}p {color: blue;
}
</style>

在这个示例中,我们定义了一个名为 ExampleComponent 的 Vue 组件,并使用 scoped 属性定义了组件的样式。样式中的 .example 类和 p 元素的样式只会作用于当前组件,不会影响到其他组件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/303348.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软件可靠性基本概念_1.定义和定量描述

1.软件可靠性定义 软件可靠性&#xff08;Software Reliability&#xff09;是软件产品在规定的条件下和规定的时间区间完成规定功能的能力。规定的条件是指直接与软件运行相关的使用该软件的计算机系统的状态和软件的输入条件&#xff0c;或统称为软件运行时的外部输入条件&am…

LeetCode-2529题:正整数和负整数的最大计数(原创)

【题目描述】 给你一个按 非递减顺序 排列的数组 nums &#xff0c;返回正整数数目和负整数数目中的最大值。换句话讲&#xff0c;如果 nums 中正整数的数目是 pos &#xff0c;而负整数的数目是 neg &#xff0c;返回 pos 和 neg二者中的最大值。注意&#xff1a;0 既不是正整…

开启RabbitMQ的WEB管理功能。

前言 今天讲下如何快速开启RabbitMQ的WEB管理功能&#xff0c;以及遇到的问题。 前期准备&#xff0c;需要安装好docker、docker-compose的运行环境。 一、安装RabbitMQ 1、创建相关目录&#xff0c;执行如下命令。 mkdir -p /docker/rabbitmq/data cd /docker/rabbitmq 2…

【数据结构】考研真题攻克与重点知识点剖析 - 第 7 篇:查找

前言 本文基础知识部分来自于b站&#xff1a;分享笔记的好人儿的思维导图与王道考研课程&#xff0c;感谢大佬的开源精神&#xff0c;习题来自老师划的重点以及考研真题。此前我尝试了完全使用Python或是结合大语言模型对考研真题进行数据清洗与可视化分析&#xff0c;本人技术…

无人机低空数字摄影测量系统

一、 系统概述 系统完全基于IDL设计实现&#xff0c;包括界面布局到人机交互再到底层核心函数功能。整体设计框架基于数字摄影测量的专业处理流程&#xff0c;实现了数据输入、数据预处理、影像信息检测、空间定向、地形三维建模、专题信息提取、成果输出与更新等功能。同时为…

【教程】App打包成IPA文件类型的四种方法

摘要 本教程总结了将App应用程序打包为IPA包的四种常用方法&#xff0c;包括Apple推荐的方式、iTunes拖入方法、自动编译脚本和解压改后缀名方法。每种方法都有其特点和适用场景&#xff0c;在实际开发中可以根据需求选择合适的方式进行打包。通过本教程&#xff0c;您将了解到…

Linux--进程的概念(二)

目录 一、进程的优先级1.1 基本概念1.2 查看进程优先级1.3 PRI&NI1.4 如何更改进程的优先级1.4.1 用top命令更改进程的nice1.4.2 用renice命令更改进程的nice 1.5 其他概念 二、环境变量2.1 基本概念2.2 常见的环境变量2.3 查看环境变量2.3.1 测试PATH2.3.2 测试HOME2.3.3 …

Adobe Photoshop 2024 v25.6强大的图形编辑工具

Adobe Photoshop 2024是一款非常强大的图像处理软件&#xff0c;具有丰富的功能和工具&#xff0c;可以满足各种图像处理需求。 软件下载&#xff1a;Adobe Photoshop 2024 v25.6中文激活版 它不仅支持基本的图像编辑和调整&#xff0c;还具有高级的特性&#xff0c;如智能对象…

自定义类型—结构体

目录 1 . 结构体类型的声明 1.1 结构的声明 1.2 结构体变量的创建与初始化 1.3 结构体的特殊声明 1.4 结构体的自引用 2. 结构体内存对齐 2.1 对齐规则 2.2 为什么存在内存对齐 2.3 修改默认对齐数 3. 结构体传参 4.结构体实现位段 4.1 位段的内存分配 1 . 结构体类…

idea中jdk版本的配置

配置JDK版本的步骤如下&#xff1a; 下载JDK安装文件&#xff1a;首先&#xff0c;需要从Oracle官方网站&#xff08;https://www.oracle.com/java/technologies/javase-jdk8-downloads.html&#xff09;下载适合您操作系统的JDK版本。 安装JDK&#xff1a;双击下载的安装文件…

LangChain-15 Manage Prompt Size 管理上下文大小,用Agent的方式询问问题,并去百科检索内容,总结后返回

背景描述 这一节内容比较复杂&#xff1a; 涉及到使用工具进行百科的检索&#xff08;有现成的插件&#xff09;有AgentExecutor来帮助我们执行后续由于上下文过大&#xff0c; 我们通过计算num_tokens&#xff0c;来控制我们的上下文 安装依赖 pip install --upgrade --qu…

Cherno CPP学习笔记-01-背景知识

0、工具网站收集 C语言版本特性 https://en.cppreference.com https://www.cplusplus.com https://www.tutorialspoint.com/cplusplus https://www.learncpp.com https://github.com/fffaraz/awesomecpp https://stackoverflow.com 网页CPP编译器 [C] gcc 12.1.0 - Wa…

SpringBoot集成Skywalking日志收集

在实际项目中&#xff0c;为了方便线上排查问题&#xff0c;尤其是微服务之间调用链路比较复杂的系统中&#xff0c;通过可视化日志的手段仍然是最直接也很方便的排查定位问题的手段&#xff0c;比如大家熟悉的ELK就是一种比较成熟的可视化日志展现方式&#xff0c;在skywalkin…

在Windows电脑上上传iOS应用至App Store

引言 &#x1f4f1; 使用UniApp开发iOS应用十分便捷&#xff0c;一套代码即可兼容多个平台。然而&#xff0c;UniApp开发iOS应用需要进行证书打包和将IPA文件上传至App Store&#xff0c;这两个步骤通常需要在Mac电脑上完成。那么&#xff0c;如果我们使用的是Windows开发环境…

Linux:gcc

Linux&#xff1a;gcc gcc概述语言发展史gcc的编译过程预处理编译汇编 gcc的链接过程动态库与静态库 gcc概述 GCC&#xff08;英文全拼&#xff1a;GNU Compiler Collection&#xff09;是 GNU 工具链的主要组成部分&#xff0c;是一套以 GPL 和 LGPL 许可证发布的程序语言编译…

C语言 | Leetcode C语言题解之第17题电话号码的字母组合

题目&#xff1a; 题解&#xff1a; char phoneMap[11][5] {"\0", "\0", "abc\0", "def\0", "ghi\0", "jkl\0", "mno\0", "pqrs\0", "tuv\0", "wxyz\0"};char* digits…

【算法】双指针算法

个人主页 &#xff1a; zxctscl 如有转载请先通知 题目 1. 283. 移动零1.1 分析1.2 代码 2. 1089. 复写零2.1 分析2.2 代码 3. 202. 快乐数3.1 分析3.2 代码 4. 11. 盛最多水的容器4.1 分析4.2 代码 5. LCR 179. 查找总价格为目标值的两个商品5.1 分析5.2 代码 6. 15. 三数之和…

MySQL 优化总结

目标知识 MySQL执行流程图 MySQL 优化成本路线图 优化成本&#xff1a;硬件>系统配置>数据库表结构>SQL及索引。优化效果&#xff1a;硬件<系统配置<数据库表结构<SQL及索引。 MySQL 五大优化原则 减少数据返回&#xff1a;设置合理字段数据类型、启用压缩…

C++——list类及其模拟实现

前言&#xff1a;这篇文章我们继续进行C容器类的分享——list&#xff0c;也就是数据结构中的链表&#xff0c;而且是带头双向循环链表。 一.基本框架 namespace Mylist {template<class T>//定义节点struct ListNode{ListNode<T>* _next;ListNode<T>* _pre…

京东云16核64G云服务器租用优惠价格500元1个月、5168元一年,35M带宽

京东云16核64G云服务器租用优惠价格500元1个月、5168元一年&#xff0c;35M带宽&#xff0c;配置为&#xff1a;16C64G-450G SSD系统盘-35M带宽-8000G月流量 华北-北京&#xff0c;京东云活动页面 yunfuwuqiba.com/go/jd 活动链接打开如下图&#xff1a; 京东云16核64G云服务器…