vue学习的预备知识为学好vue打好基础

目录

    • Vue是什么 ?
    • 如何使用Vue ?
    • Vue Api
      • Vue入口api
      • Vue实例api
      • Vue函数api
    • 无构建过程的渐进式增强静态HTML
    • Vue模块化构建工具
    • npm
    • yarn
    • Webpack
    • vue-cli
    • Vite

Vue是什么 ?

文章基于Vue3叙述。

Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的 JavaScript 框架。它基于标准 HTML、CSS 和 JavaScript 构建,并提供了一套声明式的、组件化的编程模型,帮助你高效地开发用户界面。 1

  1. Js框架:Vue是一套Javascript框架用于构建页面
  2. 声明式渲染:Vue 基于标准 HTML 拓展了一套模板语法,使得我们可以声明式地描述最终输出的 HTML 和 JavaScript 状态之间的关系。
  3. 响应性:Vue 会自动跟踪 JavaScript 状态并在其发生变化时响应式地更新 DOM。
  4. 渐进式框架:Vue 的设计非常注重灵活性和“可以被逐步集成”,引入即用。

如何使用Vue ?

本文均基于选项式 API,对于组合式api可以自行了解

在这里插入图片描述

Vue官方提供了多种Vue使用方式,最常见的还是无需构建的纯HTML,和单页面(SPA)与单文件组件(SFC)的构建使用方式。

再最新的Vue3中提供了两种vue语法,分别是:选项式 API组合式 API。其主要不同集中在script

  • 选项式api
<script>
export default {
  // reactive state
  data() {
    return {
      count: 0
    }
  },

  // functions that mutate state and trigger updates
  methods: {
    increment() {
      this.count++
    }
  },

  // lifecycle hooks
  mounted() {
    console.log(`The initial count is ${this.count}.`)
  }
}
</script>

<template>
  <button @click="increment">Count is: {{ count }}</button>
</template>
  • 组合式api
<script setup>
import { ref, onMounted } from 'vue'

// 响应式状态
const count = ref(0)

// 用来修改状态、触发更新的函数
function increment() {
  count.value++
}

// 生命周期钩子
onMounted(() => {
  console.log(`The initial count is ${count.value}.`)
})
</script>

<template>
  <button @click="increment">Count is: {{ count }}</button>
</template>

可见组合式api最贴切原生js。

了解大致的不同就可以选择一种学习了,另外对于vue的使用使用构建工具会稍微复杂一些还需要学习其他知识。

Vue对HTML,CSS,JS的扩展,Vue框架是前端开发更容易得力功能的扩展,具体如下:

  1. 每个 Vue 应用都是通过 createApp 函数创建一个新的 应用实例:
import { createApp } from 'vue'

const app = createApp({
  /* 根组件选项 */
})
  1. Vue实例挂在到html
// 部分内容省略
// html
<div id="app"></div>


// js
app.mount('#app')

应用根组件的内容将会被渲染在容器元素里面。容器元素自己将不会被视为应用的一部分。

在这里插入图片描述
3. vue实例暴露配置

应用实例会暴露一个 .config 对象允许我们配置一些应用级的选项

app.config.errorHandler = (err) => {
  /* 处理错误 */
}
  1. vue扩展html模板组件

vue提供了自己的语法实现声明式响应式,这个模板可以在html的任何地方被使用,由于无构建vue使用没有单文件组件,却提供了template语法以类似innerHtml的方式以js方式构建模板,且提供app.component()全局注册。

app.component('TodoDeleteButton', TodoDeleteButton)
  1. vue扩展html支持多实例

应用实例并不只限于一个。createApp API 允许你在同一个页面中创建多个共存的 Vue 应用,而且每个应用都拥有自己的用于配置和全局资源的作用域。

const app1 = createApp({
  /* ... */
})
app1.mount('#container-1')

const app2 = createApp({
  /* ... */
})
app2.mount('#container-2')
  1. vue扩展js实用功能

在使用vue式所有js都要写在vue实例中,不然就是原生的js,在vue中的js实现了一个vue实例的对象,严格遵循ES6规范。

<script type="module">
import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'

createApp({
    data() {
        return {
            message: 'Hello Vue!'
        }
    }
}).mount('#app')

在上述代码中{ data(){} }是一个对象,data()是类的方法,createApp通过传入的配置类创建了一个vue实例。

该方式也叫vue的选项式api。类的方法被用作定义vue的实例的具体方法,后续简称api。

经过上述描述已经学会使用data(){{}}模板显示简单数据,下一节来介绍更多api,更灵活运用vue。

Vue Api

vue是vue配置类对js的封装实现了vue的声明式和响应式功能,也是vue的基础,学会vue api更灵活使用vue。

api大全

官网入口在这里:应用实例 API

在这里插入图片描述

Vue入口api

在cdn中是Vue,通过Vue引入createApp方法

const { createApp } = Vue

createApp({
  data() {
    return {
      message: 'Hello Vue!'
    }
  }
}).mount('#app')

在es6模块也引入createApp方法

<script type="module">
import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'

createApp({
    data() {
        return {
            message: 'Hello Vue!'
        }
    }
}).mount('#app')

入口api用于创建vue实例

version指代vue版本

import { version } from 'vue'

console.log(version)

Vue实例api

app.mount()将应用实例挂载在一个容器元素中,是页面使用vue的基础

app.component()全局注册组件,用于vue模板语法

app.use()vue实例扩展插件,整合其他js框架的接口

app.config每个应用实例都会暴露一个 config 对象,其中包含了对这个应用的配置设定

app.config.errorHandler用于为应用内抛出的未捕获错误指定一个全局处理函数

app.config.globalProperties一个用于注册能够被应用内所有组件实例访问到的全局属性的对象

在这里插入图片描述

Vue函数api

  • data()定义数据初始值的api,所有会用到的顶层数据属性都应该提前在这个对象中声明。
data() {
    return {
        message: 'Hello Vue!'
    }
}
  • props用于声明一个组件的 props

该属性用于组件通讯详情

  • computed用于声明要在组件实例上暴露的计算属性

  • methods用于声明方法的api,所有的方法都要在接口实现

  • watch用于声明在数据更改时调用的侦听回调

  • emitsvue子组件与父组件共享数据(自定义事件)

  • template用于声明组件的字符串模板,vue提供的类innerHtml方法用于打造vue的模板语法,用来替代单文件组件(无构建过程使用方式)

template声明在最外层代表会取代挂载的DOM也就是mount('#app')挂载的结构。一般用于组件注册处代替单文件组件。

  • render用于编程式地创建组件虚拟 DOM 树的函数。

  • 声明周期及钩子函数,如下

在这里插入图片描述

从组件初始化到销毁过程的函数。后续详细介绍。

  • name用于显式声明组件展示时的名称。

  • components用于注册对当前组件实例可用的组件

  • this泛指组件实例,暴露实例可访问属性

在这里插入图片描述


在这里插入图片描述

无构建过程的渐进式增强静态HTML

不建议使用该种方式,模块化开发时趋势,使用node及相关构建工具是行业趋势。

使用上述方式使用vue需要了解什么式CDN2。有了CDN后才可以获取这个资源从而使用这个框架,例如使用vue框架式,vue就是一个javascript库(就是vue.js),引入后才可以使用这个框架来构建vue项目。

除了使用cdn外还可以直接将资源(vue.js)下载到本地直接使用,但是要注意及时更新。

CDN引入方式:

<script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

cdn方式使用vue是有一定缺陷的,如下

在这里插入图片描述
单文件组件就是以.vue结尾的文件,内含vue语法,构建过程会将vue组件解析为html,css,js等文件,没有构建

如下所示就是html中使用vue的案例:

<!DOCTYPE html>
<html>
    <head>
        <meta>
        <title>vue-test</title>
        <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
    </head>
    <body>
        <h1>Vue-Example</h1>

        <div id="app">{{ message }}</div>

        
    </body>

    <script>
        const { createApp } = Vue
        
        createApp({
          data() {
            return {
              message: 'Hello Vue!'
            }
          }
        }).mount('#app')
      </script>
</html>

现在大多数浏览器已经支持ES6语法,通过javascript也可以引入cdn,如下所示:

<!DOCTYPE html>
<html>
    <head>
        <meta>
        <title>vue-test</title>
    </head>
    <body>
        <h1>Vue-Example</h1>

        <div id="app">{{ message }}</div>

        
    </body>

    <script type="module">
    import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'
    
    createApp({
        data() {
        return {
            message: 'Hello Vue!'
        }
        }
    }).mount('#app')
    </script>
</html>

注意<script type="module">的module开启es6模块化开发

推荐使用es6模块引入,模块化开发式趋势,旧的<script>标签不够灵活。

在前面说到无构建过程使用vue是无法使用vue单文件组件的,如下

<!DOCTYPE html>
<html>
    <head>
        <meta>
        <title>vue-test</title>
    </head>
    <body>
        <h1>Vue-Example</h1>

        <div id="app">{{ message }}</div>
        <H1></H1>

        
    </body>

    <script type="module">
    import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'

    import Hi from './component/hello.vue'
    
    createApp({
        data() {
            return {
                message: 'Hello Vue!'
            }
        },
        components:{
            Hi
        }
    }).mount('#app')
    </script>
</html>

在这里插入图片描述

在这里插入图片描述

基于http的工作方式在构建式vue开发叙述。

现代浏览器大多都支持ES6语法,主流都走向了以node为基础的模块化开发,此处基于CDN引入的方式不再过多介绍。

Vue模块化构建工具

npm

node是使javascript脱离浏览器运行的环境。npm是在node环境下管理js公共模块包的包管理工具。

什么是 npm —— 写给初学者的编程教程

在这里插入图片描述

在这里插入图片描述

npm中文文档

npm

  • npm init 创建一个 package.json 文件
  • npm install安装一个包

node

了解了node和npm后可以知道,vue的模块开发需要两个环境,第一是脱离浏览运行的ES6环境就是node,第二需要npm来进行包管理。

yarn

Yarn是facebook发布的一款取代npm的包管理工具。

在这里插入图片描述

npm是node内置包管理工具,因此使用yarn也需要借助npm安装。

yarn中文网

npm install --global yarn

在这里插入图片描述
在这里插入图片描述
yarn run运行定义在package.jsonscript配置的脚本

yarn-cli

yarn官网

Webpack

webpack是基于node开发项目的包管理工具,用于管理ES6项目,可以是前端也可以是后端项目,js项目均可,也提供了对vue的支持,是一个全能的用于现代 JavaScript 应用程序的 静态模块打包工具。

webpack中文网

webpack中文文档

使用npm init命令可以构建一个简单的js模块,但是使用框架类似于vue框架简单的结构不再满足,使用webpack工具管理大型项目有助于提高效率。

在这里插入图片描述

前端开发这要学好哈,小编是后端,学学vue工作需要,就不再过多深入了,主要介绍vue官方提供的工具,看后两节。

vue-cli

vue-cli官网

vue-cli是基于webpack的vue项目构建工具

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

参考官方网站安装脚手架,vue-cli提供了两种创建项目的方式:

# 基于【命令行】的方式创建
vue create [项目名称]

# 基于vue UI【可视化面板】方式创建
vue ui
  1. 在终端下运行 vue ui 命令,自动在浏览器中打开创建项目的可视化面板

在这里插入图片描述

  1. 在详情页面填写项目名称:

在这里插入图片描述

  1. 在预设页面选择手动配置项目

在这里插入图片描述

  1. 在功能页面勾选需要安装的功能(Choose Vue Version、Babel、CSS 预处理器、使用配置文件)

在这里插入图片描述

  1. 在配置页面勾选 vue 的版本和需要的预处理器

在这里插入图片描述

  1. 将刚才所有的配置保存为预设(模板),方便下一次创建项目时直接复用之前的配置

在这里插入图片描述

  1. 项目创建完成后,自动进入项目仪表盘

在这里插入图片描述

vue ui实际也是使用vue命令行创建。

随着vue3的发展vue官方提供vue全套的开发及构建工具vite,更方便的构建vue项目。推荐使用vite移步下一节。

Vite

vue3速成教程

vite中文官方文档

vite学习笔记

会使用vite创建vue项目就可以上手开发啦。


  1. 引用自vue官网 ↩︎

  2. CDN的全称是Content Delivery Network,即内容分发网络。CDN是构建在现有网络基础之上的智能虚拟网络,依靠部署在各地的边缘服务器,通过中心平台的负载均衡、内容分发、调度等功能模块,使用户就近获取所需内容,降低网络拥塞,提高用户访问响应速度和命中率。CDN的关键技术主要有内容存储和分发技术。 ↩︎

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

179. 最大数(LeetCode)

文章目录 前言一、题目讲解二、算法原理三、代码编写1.仿函数写法2.lambda表达式 四、验证五.总结 前言 在本篇文章中&#xff0c;我们将会带着大家采用贪心的方法解决LeetCode中最大数这道问题&#xff01;&#xff01;&#xff01; 一、题目讲解 一组非负整数&#xff0c;包…

【面试经典 150 | 图】被围绕的区域

文章目录 写在前面Tag题目来源解题思路方法一&#xff1a;深搜方法二&#xff1a;广搜 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法&#xff0c;两到三天更新一篇文章&#xff0c;欢迎催更…… 专栏内容以分析题目为主&#xff0c;并附带一些对于本题涉及到的…

03.Kafka 基本使用

Kafka 提供了一系列脚本用于命令行来操作 kafka。 1 Topic 操作 1.1 创建 Topic 创建一个名为 oldersix-topic 的 topic&#xff0c;副本数设置为3&#xff0c;分区数设置为2&#xff1a; bin/kafka-topics.sh \ --create \ --zookeeper 192.168.31.162:2181 \ --replication…

ROS1快速入门学习笔记 - 07话题消息的定义与使用

目录 一、话题模型 二、自定义话题消息 1. 在功能包下创建msg目录用于存储话题文件 2. 在package.xml文件中添加功能包依赖&#xff1b; 3. 在CMakeLists.txt增加编译选项&#xff1b; 4. 完成编译 5. 配置CMakeLists.txt中的编译规则&#xff08;增加发布者和订阅者&am…

卫浴品牌商家做展示预约小程序的作用是什么

卫浴品牌类别多、普通/智能、场景化等&#xff0c;无论企业还是经销商市场门店都比较饱满&#xff0c;虽然市场需求度高&#xff0c;但同样需要商家不断拓宽销售渠道和挖掘客户价值&#xff0c;破圈增长。 线上多平台发展尤为重要&#xff0c;而小程序作为连接点&#xff0c;对…

ctf web-部分

** web基础知识 ** *一.反序列化 在PHP中&#xff0c;反序列化通常是指将序列化后的字节转换回原始的PHP对象或数据结构的过程。PHP中的序列化和反序列化通过serialize()和unserialize()函数实现。 1.序列化serialize() 序列化说通俗点就是把一个对象变成可以传输的字符串…

就业班 第三阶段(nginx) 2401--4.26 day5 nginx5 nginx https部署实战

三、HTTPS 基本原理 1、https 介绍 HTTPS&#xff08;全称&#xff1a;HyperText Transfer Protocol over Secure Socket Layer&#xff09;&#xff0c;其实 HTTPS 并不是一个新鲜协议&#xff0c;Google 很早就开始启用了&#xff0c;初衷是为了保证数据安全。 近些年&…

ArcGIS小技巧—模型构建器快速提取河网

上篇文章介绍的基于DEM的河网提取&#xff0c;需要使用多个工具&#xff0c;整体操作比较繁琐&#xff0c;在日常工作中&#xff0c;使用Arcgis提供的模型构建器可以帮助我们将多个工具整合在一起&#xff0c;在面对大量数据批量处理时&#xff0c;可以大大提高工作效率 利用模…

【题解】—— LeetCode一周小结17

【题解】—— 每日一道题目栏 上接&#xff1a;【题解】—— LeetCode一周小结16 22.组合总和 Ⅳ 题目链接&#xff1a;377. 组合总和 Ⅳ 给你一个由 不同 整数组成的数组 nums &#xff0c;和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数…

基于SSM的“个性化电子相册”的设计与实现(源码+数据库+文档+PPT)

基于SSM的“个性化电子相册”的设计与实现&#xff08;源码数据库文档PPT) 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SSM 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 个性化电子相册功能结构图 系统后台界面 会员信息管理界面 相…

在网站源码后台增加响应式布局

一本教材上的网站源码&#xff0c;后台在手机上查看还是按照电脑的页面样式&#xff0c;不方便查看和发布新内容。教材上讲了响应式布局。对于页面结构简单的网站&#xff0c;可以利用响应式&#xff0c;使页面自动适用各种屏幕的分辨率。 今天在一个网站源码的后台使用了响应…

经典案例:学习 Java 异常处理的最佳实践

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一个人虽可以走的更快&#xff0c;但一群人可以走的更远。 我是一名后…

OpenCV如何模板匹配

返回:OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 上一篇&#xff1a;OpenCV如何实现背投 下一篇 &#xff1a;OpenCV在图像中寻找轮廓 目标 在本教程中&#xff0c;您将学习如何&#xff1a; 使用 OpenCV 函数 matchTemplate()搜索图像贴片和输入图像之间…

为什么我的Mac运行速度变慢 mac运行速度慢怎么办 如何使用CleanMyMac X修复它

近些年伴随着苹果生态的蓬勃发展&#xff0c;越来越多的用户开始尝试接触Mac电脑。然而很多人上手Mac后会发现&#xff0c;它的使用逻辑与Windows存在很多不同&#xff0c;而且随着使用时间的增加&#xff0c;一些奇奇怪怪的文件也会占据有限的磁盘空间&#xff0c;进而影响使用…

电脑已经有了一个Windows10,再多装一个Windows10组成双系统

前言 前段时间已经讲过一次双Windows系统的安装教程&#xff0c;但是小白重新去看了一下&#xff0c;发现写的内容太多&#xff0c;怕小伙伴看了之后一脸萌。 所以今天咱们就重新再来讲讲&#xff1a;在同一台机器上安装Windows10双系统的教程。 注意哦&#xff01;这里的Wi…

用来传输文件的协议-FTP

一.FTP协议--文件传输协议 1.了解FTP协议 &#xff08;1&#xff09;FTP服务是用来传输文件的协议 FTP&#xff08;File Transfer Protocol&#xff0c;文件传输协议&#xff09;是TCP/IP协议组中的协议之一&#xff0c;用于互联网上的控制文件的双向传输。是传输文件到Linu…

C++:string 类

在C中定义一个 std::string 字符串可以采用以下几种方式&#xff1a; 1.使用字符串字面量初始化&#xff1a; std::string str "Hello, world!"; 2.使用构造函数初始化&#xff1a; std::string szStringB("Hello wolven"); 3.使用重复字符初始化&am…

51单片机入门(一)

1. 51单片机的基础介绍 2. RAM和ROM的区别 总体而言&#xff0c;RAM和ROM在计算机系统中起着不同的角色&#xff0c;RAM用于临时存储运行时数据&#xff0c;而ROM用于存储永久性的固件和系统程序。 3. 为什么叫51单片机 因为51系列单片机都是使用Intel 8031指令系统的单片机…

【链表——数据结构】

文章目录 1.单链表1.定义2.基本操作2.1.不带头结点2.2后插2.3前插2.4删除2.5按位查找2.6按值查找2.7求单链表长度2.8 建表 2.双链表1.初始化2.插入(后插)3.删除(后删)4.遍历 3.循环链表1.循环单链表2.循环双链表3.代码问题 4.静态链表1.简述基本操作的实现1.初始化3.删除某个结…

前端---Bootstrap---的下载和使用

目录 Bootstrap的下载 网页链接: 下载步骤: Bootstrap的使用 引用步骤: Bootstrap常用: Bootstrap-栅格系统 Bootstrap-组件 Bootstrap 是由 Twiter 公司开发维护的前端 U框架&#xff0c;它提供了大量编写好的 CSS 样式&#xff0c;允许开发者结合一定 HTML结构及JavaS…