前端工程化是使用软件工程的方法来单独解决前端的开发流程中模块化、组件化、规范化、自动化的问题,其主要目的为了提高效率和降低成本。
前端工程化实现的技术栈有很多,我们采用ES6+nodejs+npm+Vite+VUE3+router+pinia+axios+Element-plus组合来实现
模块化是一种组织和管理前端代码的方式,将代码拆分成小的模块单元,使得代码更易于维护、扩展和复用。它包括了定义、导出、导入以及管理模块的方法和规范。前端模块化的主要优势如下:
目前,前端模块化有多种规范和实现,包括 CommonJS、AMD 和 ES6 模块化。ES6 模块化是 JavaScript 语言的模块标准,使用 import 和 export 关键字来实现模块的导入和导出。现在,大部分浏览器都已经原生支持 ES6 模块化,因此它成为了最为广泛使用的前端模块化标准. `
ES6中无论以何种方式导出,导出的都是一个对象,导出的内容都可以理解为是向这个对象中添加属性或者方法
//1.分别暴露
// 模块想对外导出,添加export关键字即可!
// 导出一个变量
export const PI = 3.14
// 导出一个函数
export function sum(a, b) {
return a + b;
}
// 导出一个类
export class Person {
constructor(name, age) {
this.name = name;
this.age = age;
}
sayHello() {
console.log(`Hello, my name is ${this.name}, I'm ${this.age} years old.`);
}
}
/*
*代表module.js中的所有成员
m1代表所有成员所属的对象
*/
import * as m1 from './module.js'
// 使用暴露的属性
console.log(m1.PI)
// 调用暴露的方法
let result =m1.sum(10,20)
console.log(result)
// 使用暴露的Person类
let person =new m1.Person('张三',10)
person.sayHello()
//2.统一暴露
// 模块想对外导出,export统一暴露想暴露的内容!
// 定义一个常量
const PI = 3.14
// 定义一个函数
function sum(a, b) {
return a + b;
}
// 定义一个类
class Person {
constructor(name, age) {
this.name = name;
this.age = age;
}
sayHello() {
console.log(`Hello, my name is ${this.name}, I'm ${this.age} years old.`);
}
}
// 统一对外导出(暴露)
export {
PI,
sum,
Person
}
/*
{}中导入要使用的来自于module.js中的成员
{}中导入的名称要和module.js中导出的一致,也可以在此处起别名
{}中如果定义了别名,那么在当前模块中就只能使用别名
{}中导入成员的顺序可以不是暴露的顺序
一个模块中可以同时有多个import
多个import可以导入多个不同的模块,也可以是同一个模块
*/
//import {PI ,Person ,sum } from './module.js'
//import {PI as pi,Person as People,sum as add} from './module.js'
import {PI ,Person ,sum,PI as pi,Person as People,sum as add} from './module.js'
// 使用暴露的属性
console.log(PI)
console.log(pi)
// 调用暴露的方法
let result1 =sum(10,20)
console.log(result1)
let result2 =add(10,20)
console.log(result2)
// 使用暴露的Person类
let person1 =new Person('张三',10)
person1.sayHello()
let person2 =new People('李四',11)
person2.sayHello()
// 3默认和混合暴露
/*
默认暴露语法 export default sum
默认暴露相当于是在暴露的对象中增加了一个名字为default的属性
三种暴露方式可以在一个module中混合使用
*/
export const PI = 3.14
// 导出一个函数
function sum(a, b) {
return a + b;
}
// 导出一个类
class Person {
constructor(name, age) {
this.name = name;
this.age = age;
}
sayHello() {
console.log(`Hello, my name is ${this.name}, I'm ${this.age} years old.`);
}
}
// 导出默认
export default sum
// 统一导出
export {
Person
}
/*
*代表module.js中的所有成员
m1代表所有成员所属的对象
*/
import * as m1 from './module.js'
import {default as add} from './module.js' // 用的少
import add2 from './module.js' // 等效于 import {default as add2} from './module.js'
// 调用暴露的方法
let result =m1.default(10,20)
console.log(result)
let result2 =add(10,20)
console.log(result2)
let result3 =add2(10,20)
console.log(result3)
// 引入其他方式暴露的内容
import {PI,Person} from './module.js'
// 使用暴露的Person类
let person =new Person('张三',10)
person.sayHello()
// 使用暴露的属性
console.log(PI)
原npm地址
C:\Users\nanchengyu\AppData\Roaming\npm
安装依赖 (查看所有依赖地址 https://www.npmjs.com )
解决链接:(方式一即可解决)
这个报错存在于之前安装过npm,而有没有将全局的下载的依赖从原来C盘更改到其他盘的情况
npm安装报错(npm ERR! code EPERM npm ERR! syscall mkdir npm ERR! path C:\Program Files\nodejs\node_ca...)-CSDN博客
hello vue
{{message}}
工程化管理项目
类似于ant design pro
1.下面是 Vite 项目结构和入口的详细说明:
2.vite的运行界面
{
"scripts": {
"dev": "vite", // 启动开发服务器,别名:`vite dev`,`vite serve`
"build": "vite build", // 为生产环境构建产物
"preview": "vite preview" // 本地预览生产构建产物
}
}
//修改vite项目配置文件 vite.config.js
export default defineConfig({
plugins: [vue()],
server:{
port:3000
}
})
一个.vue文件构成一个页面组件
导入css方式(App.vue)
1.1. {{}}里面放入属性名即可
msg的为{{msg}}
msg的值为{{getMsg()}}
年龄:{{age}},是否成年{{age > 18?'是':'否'}}
{{bee.split('').reverse().join('')}}
1. 命令必须依赖标签,在开始标签中使用
2. v-text 不识别html结构中的文本
v-html识别文本中的html代码的命令
3.属性渲染命令 v-bind 将数据绑定到元素的属性上
v-bind:属性="属性名"
简写:
:属性="属性名"
4. v-on绑定事件
v-on:事件名称=“函数名()”
v-on:事件名可以简写为 @事件名
在script中需要.value属性修饰
在template中不需要,可以直接调用函数中的方法即可
在script和template中都不需要,可以直接调用对象.属性名即可
v-if="表达式"数据为true 则当前元素会渲染进入dom树
v-else自动和前一个v-if做取反操作
v-show=""数据为true元素则展示在页面上,否则不展示
v-if 数据为false时,元素则不再dom树中了
v-show数据为false时,元素仍然在dom树中,通过display的css样式控制元素隐藏
Vue is awesome!
Oh no
-
{{item.message}}
单向绑定 v-bind 响应式数据发生变化时,更新dom树 用户的操作如果造成页面内容的变化不会影响响应式数据
双向绑定 v-model 页面上的数据由于用户的操作造成了变化,也会同步修改对应的响应式数据
双向绑定一般都用于表单标签
双向绑定也有人称呼为收集表单信息的命令
v-model:value="数据" 双向绑定 但是一般 value可以省略 v-model=""
账号:
密码:
爱好:
吃
喝
玩
乐
简介:
籍贯:
显示爱好:{{ hbs }}
显示用户信息:{{ user }}
解决传统的回调函数
普通函数: 正常调用的函数,一般函数执行完毕后才会继续执行下一行代码
回调函数: 一些特殊的函数,表示未来才会执行的一些功能,后续代码不会等待该函数执行完毕就开始执行了
在前端开发中,回调函数类似于Java中的接口(interface)或者匿名类(anonymous class)。回调函数是一种通过将函数作为参数传递给其他函数,并在某个事件发生或异步操作完成时执行的机制。这种模式常用于处理用户输入、异步请求、定时器等情况。
ajax
处理多数据共享