【vue3学习P5-P10】vue3语法;vue响应式实现

0、vue2和vue3对比

框架版本API方式双向绑定原理domFragmentsTree-Shaking
vue2选项式API(Options API)基于Object.defineProperty(监听)实现,不能双向绑定对象类型的数据【通过Object.defineProperty里面的set和get做对象劫持,在处理数组等对象类型数据时,则是重写原型方法(push、pop等方法可以被监听)】每次更新diff,都是全量对比<template>标签里面只能有一个根节点<div>标签import语法引用组件:import xxx from xxx
vue3组合式API(Composition API)基于Proxy(劫持)实现,能够双向绑定对象类型的数据只对比有标记的,对标记部分进行更新(大大减少静态内容的对比消耗,动态内容是{{}}双向绑定的内容)<template>标签里面支持多个根节点<div>标签(实现原理:通过虚拟节点实现)import语法引用组件时,将全局API分块,不使用的功能不会出现在基础包中,减少打包体积:import {aaa} from xxx
0.1 vue3新特性:
  • 重写双向数据绑定
  • VDOM性能瓶颈
  • Fragments:增加了Suspense teleport和多v-model用法
  • Tree-Shaking的支持:在保持代码运行结果不变的情况下,去除无用的代码
  • 组合式API(Composition API)
  • setup语法糖
0.2 vue3的三种书写风格
  • Options API
  • setup
  • setup 语法糖
// 第一种书写风格:Options API
<template>
</template>

<script>
export default{
	data() {
		return{
			// 数据
		}
	},
	methods: {}
}
</script>

<style>
</style>

// 第二种书写风格setup
<template>
	<div>
		{{a}}
	</div>
</template>

<script>
setup() {
	const a = 1

	// 变量需要手动return才能在dom中使用
	return{
		a
	}
}
</script>

<style>
</style>

// 第三种书写风格setup语法糖(后+lang选择使用是js语言)
<template>
	<div>
		{{a}}
	</div>
</template>

<script setup lang="ts">
const a:number = 1
</script>

<style>
</style>

1、vue语法

vue语法:

  • 插值语法:{{}}
  • 指令语法:v-
1.1 插值语法
<template>
	<div>
		<p>{{data}}</p>
	</div>
</template>

<script setup lang="ts">
const data = {
	name: '张三',
	age: 30,
	like: '吃饭'
}
</script>

<style scoped>
</style>

1.2 vue指令

v-开头的都是vue内置指令
v-text 用来显示文本
v-html 用来展示富文本(支持标签,如<span>xxx</span>,不支持组件,如<组件名>xxx</组件名>
v-if 用来控制元素的显示隐藏(切换真假DOM,false时注释掉dom节点)
v-else-if 表示 v-if 的v-else-if 可以链式调用
v-else v-if条件收尾语句
v-show 用来控制元素的显示隐藏(false时将节点设置不可见,display:none block Css切换,性能比v-if高)
v-on 简写@ 用来给元素添加/绑定事件v-on:click语法糖简写@click
v-bind 简写:用来绑定元素的属性Attr(v-bind:id语法糖简写:id
v-model 双向绑定
v-for 用来遍历元素
v-on 修饰符 冒泡案例
v-once 性能优化只渲染一次
v-memo 性能优化会有缓存

1.2.1 点击事件:动态事件类型切换
// 动态事件切换
<template>
	// 静态事件
	<button @click="clickBtn">按钮点击</button>
	// 动态事件(动态事件切换)
	<button @[event]="clickBtn">按钮点击</button>
	
</template>

<script>
// const event = "click" // @[event]等于@click
const event = "doubleClick" // @[event]等于@doubleClick
const clickBtn = ()=>{
	console.log("点击按钮了……")
}
</script>
1.2.2 点击事件:阻止点击冒泡

点击冒泡:当父级节点和子级节点都有点击事件时,点击子级节点也会触发父级节点的点击事件

// 动态事件切换
<template>
	<div @click="parentClick">
		<button @[event].stop="clickBtn">按钮点击</button>
	</div>
</template>

<script>
const parentClick = ()=>{
	console.log("点击了父级")
}
// const event = "click" // @[event]等于@click
const event = "doubleClick" // @[event]等于@doubleClick
const clickBtn = ()=>{
	console.log("点击按钮了……")
}
</script>

在这里插入图片描述

属性作用
@[event].stop阻止点击冒泡(触发父级节点的点击事件),但是:对单击事件有效,对双击事件无效
@[event].prevent阻止提交表单
@[event].once只触发一次,后面再点击多少次都不会触发
@[event].capture
@[event].middle
@[event].left
@[event].right
@[event].passive
@[event].self
1.2.3 v-bind 绑定元素属性

绑定id、class、style……

<template>
	<div :id="id">
		<p :style="style">段落段落段落</p>
		<button :class="['a', 'b']" @click.middle="clickBtn()">1按钮</button>
		<button :class="['a']" @[event].passive="clickBtn()">2按钮</button>
	</div>
</template>

<script setup>
// 事件
const event = "click" // @[event]等于@click
const clickBtn = ()=>{
	console.log("点击按钮了……")
}

// 属性
const id = "myid"
const style = {
	color: 'green',
	border: '1px solid green'
}
</script>

<style scoped>
#myid{
	background-color: #ccc;
}
.a{
	background-color: blue;
}
.b{
	color: red;
}
</style>
1.2.4 v-model 绑定表单元素(ref,响应式,双向绑定)

响应式的数据:双向绑定(通过ref和reactive)
v-model can only be used on <input>, <textarea> and <select> elements.

<template>
	<div>
		<input v-model="data" type="text"/>
		<p>{{data}}</p>
	</div>
</template>

<script setup>
import {ref} from 'vue'

// 双向绑定(通过ref和reactive)
const data = ref('测试内容')
</script>

<style scoped>
</style>

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

1.2.5 v-once 单次渲染【基本数据类型】(待完善)

v-once:仅渲染元素和组件一次,并跳过之后的更新
在随后的重新渲染,元素/组件及其所有子项将被当作静态内容并跳过染。这可以用来优化更新时的性能

<template>
	<div>
		<!-- 基本数据类型 -->
		<input v-model="msg" type="text"/>
		<!-- 对照组 -->
		<p>对照组 {{msg}}</p>
		<hr />
		<!-- v-once 实验组 -->
		<!-- 单个元素 -->
		<p v-once>This will never change:{{msg}}</p>
		<!-- 带有子元素的元素 -->
		<div v-once>
			<h1>comment</h1>
			<p>{{msg}}</p>
		</div>
		
		<!-- 待完善 -->
		<!-- 组件 -->
		<!-- <A v-once :comment="msg" /> -->
		<!-- v-for指令 -->
		<ul><li v-for="i in list" v-once>{{i}}</li></ul>
	</div>
</template>

<script setup lang="ts">
import {ref} from 'vue'
// import A from 'A.vue' // 报错
// import B from 'B.vue'

const msg = ref('测试内容')
const list:string[] = ['春', '夏', '秋', '东']
</script>

<style scoped>
</style>

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

1.2.6 v-memo 单次渲染【数组】(待完善)
<template>
	<div>
		<!-- v-memo 处理对象数据类型 -->
		<!-- v-for指令 -->
		<p v-for="(item, index) in list">对照组 {{index}}--{{item}}</p>
		<hr />
		<p v-for="(item, index) in list" v-memo="index == 2">v-memo组 {{index}}--{{item}}</p>
		<!-- 组件 -->
		<!-- <A v-once :comment="msg" /> -->
	</div>
</template>

<script setup lang="ts">
import {ref, computed} from 'vue'
// import A from 'A.vue'
// import B from 'B.vue'

const msg = ref('测试内容')
let list = ref(['春', '夏', '秋', '冬'])

// 模拟异步更新
// 定时刷新数据函数-----------还没有写出来,报错
const timer = ref(0)
const index = ref(0)
let count = 1
let list = computed({
	get() {
		
	},
	set(newVal) {
		console.log("count: ", count++)
		list = ['赵', '钱', '孙', '李']
		console.log(list)
	}
})
// setTimeout(changeData, 3000)
// setTimeout(changeData, 3000)
// setTimeout(changeData, 3000)
// setInterval(changeData, 3000)


</script>

<style scoped>
</style>

1.2.7 v-for 遍历
<template>
	<div>
		<input v-for="(item, index) in data" type="text" value="item"/>
		<p :key="index" v-for="(item, index) in data">{{index}}--{{item}}</p>
	</div>
</template>

<script setup lang="ts">
import {ref} from 'vue'

const data:string[] = ['春', '夏', '秋', '东']
</script>

<style scoped>
</style>

在这里插入图片描述
从生成的dom结构来看,使用v-for的标签效果是:循环生成多个完整标签内容(标签+样式+数据),而不仅仅是生成“一个完整标签+多条数据”

2、虚拟dom和diff算法

虚拟DOM就是通过JS来生成一个AST节点树(抽象语法树)

vue3的diff算法:分为三类

  • 无key(三步)
    在这里插入图片描述
  • 有key(五步)
  • 在这里插入图片描述
  • 前序+尾序
  • 乱序(最长递增子序列)
  • 在这里插入图片描述
    在这里插入图片描述

3、Ref 全家桶

  • ref:深层次响应式
  • shallowRef:浅层次响应式
  • isRef:判断是否是ref对象,返回值true或false
  • triggerRef:强制视图更新
  • customRef:自定义ref
3.1 响应式:ref 、shallowRef、triggerRef 或 reactive

(1)非响应式:修改data之后,页面数据不更新

<template>
	<div>
		<p>{{data}}</p>
		<button @click="clickBtn()">修改</button>
	</div>
</template>

<script setup lang="ts">
let data = {name: "张三"}
const clickBtn = ()=>{
	data.name = "李四"
	console.log(data)
}
</script>

在这里插入图片描述
(2)响应式(利用ref双向绑定):修改data之后,页面数据也更新

<template>
	<div>
		<p>{{data}}</p>
		<button @click="clickBtn()">修改</button>
	</div>
</template>

<script setup lang="ts">
import {ref} from 'vue'	
let data = ref({name: "张三"}) // 使用ref
const clickBtn = ()=>{
	data.value.name = "李四" // 通过value更新
	console.log(data)
}
</script>

编辑器报错,但能用(不知道HBuilderX为什么报错,B站老师的vscode就没有报错)
在这里插入图片描述
在这里插入图片描述
(3)响应式:shallowRef

<template>
	<div>
		<p>{{data1}}</p>
		<p>{{data2}}</p>
		<button @click="clickBtn1()">修改(Ref)</button>
		<button @click="clickBtn2()">修改(shallowRef)</button>
	</div>
</template>

<script setup lang="ts">
import {ref} from 'vue'

let data1 = ref({name: "张三"})
let data2 = ref({name: "张三三"})
const clickBtn1 = ()=>{
	data1.value.name = "李四" // value.name = 
	console.log(data1)
}
const clickBtn2 = ()=>{
	data2.value = {name: "李四四"} // value = 
	console.log(data2)
}
</script>
3.2 ref、shallowRef、triggerRef

ref、shallowRef 不能同时使用(在一个事件中),shallowRef 会被影响,即使写成xxx.value.name=xxx也会被改变,造成页面(视图)的更新
在这里插入图片描述
triggerRef 强制更新,shallowRef 会被影响,由于 ref 底层调用了 triggerRef,所以 ref、shallowRef 同时使用时 shallowRef 会被影响
在这里插入图片描述

3.3 customRef(自定义ref)
<template>
	<div>
		<p>customRef: {{obj}}</p>
		<button @click="clickBtn()">修改</button>
	</div>
</template>

<script setup lang="ts">
import {customRef} from 'vue'

function MyRef(value){
	let timer = null
	return customRef((track,trigger)=>{
		return{
			get(){
				track()
				return value
			},
			set(newValue){
				// 不防抖,每次点击clickBtn都会触发(然而实际上只更新一次,因为clickBtn中修改每次都是同一个值,并不是变化的)
				// console.log("触发了")
				// value = newValue
				// trigger()
				// 防抖
				clearTimeout(timer)
				timer = setTimeout(()=>{
					console.log("触发了")
					value = newValue
					timer = null
					trigger()
				}, 3000)
			}
		}
	})
}

const obj = MyRef("王五")

const clickBtn = ()=>{
	obj.value = "修改了"
	console.log(obj)
}
</script>

在这里插入图片描述

3.5 reactive【绑定表单场景中使用较多(?)】

ref、reactive 区别:

  • ref 支持所有数据类型,reactive 支持引用类型数据Array、Object、Map、Set)
  • ref 取值、赋值都需要加上.value,reactive 不用

基础版例子

<template>
	<div>
		<p>reactive: {{form}}</p>
		<button @click="clickBtn()">修改</button>
	</div>
</template>

<script setup lang="ts">
import {reactive} from 'vue'

type M = {
	name: string,
	age: number
}
let form = reactive<M>({
	name: "张三",
	age: 30
})

const clickBtn = ()=>{
	form.name = "李四"
	form.age = 31
	console.log(form)
}
</script>

在这里插入图片描述
reactive 绑定数组,响应式更新视图

<template>
	<div>
		<ul>
			<li v-for="item in list">{{item}}</li>
		</ul>
		<button @click="clickBtn()">添加</button>
	</div>
</template>

<script setup lang="ts">
import {reactive} from 'vue'

// let list = [] // 非响应式,不会更新视图
let list = reactive([]) // 响应式,动态更新视图
// let list = reactive<string []>([]) // 添加泛型(字符串数组类型)

const clickBtn = ()=>{
	list.push("item")
	console.log(list)
}
</script>

在这里插入图片描述
异步请求场景模拟,不破坏响应式的数据更新方式示例。解决方案:数组+push+解构

<template>
	<div>
		<ul>
			<li v-for="item in list">{{item}}</li>
		</ul>
		<button @click="clickBtn()">添加</button>
	</div>
</template>

<script setup lang="ts">
import {reactive} from 'vue'

// let list = [] // 非响应式,不会更新视图
let list = reactive([]) // 响应式,动态更新视图
// let list = reactive<string []>([]) // 添加泛型(字符串数组类型)

// 模拟异步请求,更新数据
const clickBtn = ()=>{
	setTimeout(()=>{
		const res = ['one', 'two', 'three'] // 模拟后端返回数据
		// list = res // 这样赋值,list数据能更新,但是页面视图不会更新
		// 因为reactive是Proxy代理的对象,直接赋值会覆盖代理对象,破坏响应式方案
		// 解决方案
		list.push(...res) // 数组解构
		console.log(list)
	}, 300)
}
</script>

在这里插入图片描述
解决方案二:对象+数组作为对象的一个属性+直接修改对象的数组属性

<template>
	<div>
		<ul>
			<li v-for="item in list.arr">{{item}}</li>
		</ul>
		<button @click="clickBtn()">添加</button>
	</div>
</template>

<script setup lang="ts">
import {reactive} from 'vue'

// 对象+
let list = reactive<{arr:string[]}>({
	arr: []
}) // 响应式,动态更新视图

// 模拟异步请求,更新数据
const clickBtn = ()=>{
	setTimeout(()=>{
		const res = ['one', 'two', 'three'] // 模拟后端返回数据
		// list = res // 这样赋值,list数据能更新,但是页面视图不会更新
		// 因为reactive是Proxy代理的对象,直接赋值会覆盖代理对象,破坏响应式方案
		// 解决方案
		list.arr = res
		console.log(list)
	}, 300)
}
</script>

在这里插入图片描述

3.6 readonly

把 reactive 的值变成只读
但是 readonly 会受原始变量更新的影响

<script setup lang="ts">
import {reactive} from 'vue'

let obj = reactive({name: '张三'})
let obj_read = readonly(obj)
// 不能修改只读属性的值
obj_read.name = '李四' // 编译报错:obj_read 是只读属性
// 能修改原始变量的值
obj.name = '李四'
// 这里,打印 obj、obj_read,发现都会变成'李四'(readonly 会受原始变量更新的影响)
</script>

在这里插入图片描述

3.7 shallowReactive
<template>
	<div>
		<p>{{obj}}</p>
		<button @click="clickBtn()">修改</button>
	</div>
</template>

<script setup lang="ts">
import {reactive, shallowReactive} from 'vue'

let obj:any = shallowReactive({
	foo: { // 外层
		bar: { // 二层
			name: '张三' // 三层
		}
	}
})
const clickBtn = ()=>{
	console.log("点击了")
	// 修改外层【正确修改】
	obj.foo = {
		barChange: '李四'
	}
	// 【错误修改】
	// 修改二层
	// obj.foo.bar = {
	// 	nameChange: '赵六' // 非响应式
	// }
	// obj.foo.bar.value = {
	// 	nameChange: '赵六' // 追加元素
	// }
	// 修改最内层(三层)
	// obj.foo.bar.name = '李四' // 非响应式,页面视图不更新
	// 修改obj
	// obj = { // 非响应式,页面视图不更新
	// 	fooChange: '王五'
	// }
	// obj.value = { // 响应式;相当于追加一个元素:value:{fooChange: '王五'}
	// 	fooChange: '王五'
	// }
	// console.log(obj)
}
</script>

<style scoped>
</style>

修改外层【正确修改】:
在这里插入图片描述
修改二层、三层都是非响应式:
在这里插入图片描述

修改obj:
在这里插入图片描述

3.8 shallowRef、shallowReactive

相同:shallowReactive 也是浅层次响应式,与 shallowRef 会被 ref 影响相同,shallowReactive 也会被 reactive 影响
区别:
shallowRef 实现响应式需要通过.value修改数据,shallowReactive 不需要

// shallowRef
let data = ref({name: "张三"})
const clickBtn1 = ()=>{
	data.value.name = "李四" // 方式一 value.name = 
	data.value = {name: "李四四"} // 方式二 value = 
	console.log(data)
}

// shallowReactive
let obj:any = shallowReactive({
	foo: { // 外层
		bar: { // 二层
			name: '张三' // 三层
		}
	}
})
const clickBtn1 = ()=>{
	obj.foo = {
		barChange: '李四'
	}
}

4、to 全家桶

  • toRef:将普通数据转成ref对象(响应式),然后响应式修改对象的值(转成ref对象,修改值需要加.value)。只能修改响应式对象的值。非响应式对象的data会改变,但是视图不会改变。接收参数:toRef(对象名, 对象属性)
  • toRefs:批量将数据转成ref对象(响应式),然后响应式修改对象的值
  • toRaw:与toRef相反,将ref对象转成普通对象/普通类型数据,脱离Proxy代理(Proxy实现双向绑定/响应式,脱离Proxy即非响应式)。只想修改数据、不想更新视图的时候可以用toRaw
// toRef 实现响应式修改数据的值
// 转成ref对象
const like = toRef(person, 'like') // 接收参数:toRef(对象名, 对象属性)
// 响应式修改
like.value = '运动' // like是一个ref对象,所以修改值需要加.value


// toRefs
const person = reactive({
	name: '张三',
	age: 30,
	like: '吃饭'
})
// 接收参数:对象名;返回值:对象内的所有属性名
const {name, age, like} = toRefs(person) // 解构取值
// 响应式修改
name.value = '李四'
age.value = 31
like.value = '运动'

完整例子
toRef 的例子

<template>
	<div>
		<p>{{person}}</p>
		<button @click="clickBtn()">修改</button>
	</div>
</template>

<script setup lang="ts">
import {reactive, toRef} from 'vue'

const person = reactive({ // 实现对象类型数据的响应式,可以直接使用reactive(reactive实现对象类型数据的响应式,ref实现所有类型数据的响应式)
	name: '张三',
	age: 30,
	like: '吃饭'
})
const clickBtn = ()=>{
	const like = toRef(person, 'like') // 接收参数:toRef(对象名, 对象属性)
	like.value = '运动' // like是一个ref对象,所以修改值需要加.value
	console.log('like:',like)
	console.log('person:',person)
}
</script>

在这里插入图片描述
toRefs 的例子

<template>
	<div>
		<p>{{person}}</p>
		<button @click="clickBtn()">修改</button>
	</div>
</template>

<script setup lang="ts">
import {reactive, toRef, toRefs} from 'vue'

const person = reactive({
	name: '张三',
	age: 30,
	like: '吃饭'
})
// toRefs实现原理:批量转成ref对象
// const toRefs = <T extends object>(object:T)=>{
// 	const map:any = {}
// 	for(let key in object){
// 		map[key] = toRef(object, key) // 将对象object中的属性key转成ref对象
// 	}
// 	return map // 将object内所有属性转成ref并返回
// }

const clickBtn = ()=>{
	const {name, age, like} = toRefs(person) // 接收参数:对象名;返回值:对象内的所有属性名
	name.value = '李四'
	age.value = 31
	like.value = '运动'
	console.log('person:',person)
}
</script>

<style scoped>
</style>

在这里插入图片描述

【补充】ts泛型

<script setup lang="ts">
import {ref} from 'vue'	
import type {Ref} from 'vue' // 添加泛型(方式2)

type Data = {
	name: string
}
let data1 = ref<Data>({name: "张三"}) // 添加泛型(方式1)
let data2:Ref<Data> = ref({name: "张三"}) // 添加泛型(方式2)当类型比较复杂的时候推荐使用
</script>

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

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

相关文章

【Linux网络编程三】Udp套接字编程网络应用场景

【Linux网络编程三】Udp套接字编程网络应用场景 应用场景一&#xff1a;远程命令执行应用场景二&#xff1a;与Windos端相互通信应用场景三&#xff1a;简单聊天1.多线程化2.输入输出分开 应用场景一&#xff1a;远程命令执行 简单的服务器上一篇已经完成&#xff0c;接下来我…

Java项目管理01-Maven基础

一、Maven的常用命令和生命周期 1.Maven的常用命令使用方式 complie&#xff1a;编译&#xff0c;将java文件编译为class字节码文件 clean&#xff1a;清理&#xff0c;删除字节码文件 test&#xff1a;测试&#xff0c;运行项目中的test类 package&#xff1a;打包&#x…

高斯消去法 | LU分解 | PA=LU分解(MatLab)

一、问题描述 利用高斯消去法&#xff0c;LU 分解及PALU 分解求解非线性方程组。 二、实验目的 掌握高斯消去法、LU 分解、PALU 分解的算法原理&#xff1b;编写代码实现利用高斯消去法、LU 分解、PALU 分解来求解线性方程组。 三、实验内容及要求 1. 利用顺序高斯消去法求…

计算机毕业设计社区居民服务管理系统SSM

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; vue mybatis Maven mysql5.7或8.0等等组成&#xff0c;B…

Redis——SpringBoot整合Redis实战

1、基本配置 1.1、引入依赖 首先&#xff0c;建立Maven项目&#xff0c;在Maven项目中引入pom.xml文件&#xff1a; <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> &l…

HTML5和CSS3强化知识总结

HTML5的新特性 HTML5的新增特性主要是针对于以前的不足&#xff0c;增一些新的标签、新的表单和新的表单属性等。这些新特性都有兼容性问题&#xff0c;基本是IE9以上版本的浏览器才支持&#xff0c;如果不考虑兼容性问题&#xff0c;可以大量使用这些新特性。 HTML5新增的语义…

linux实时调度

面对陌生的知识体系&#xff0c;应该从什么角度来 简介 一、进程管理基本概念 在单处理器系统上&#xff0c;在给定时刻只有一个程序可以运行&#xff0c;在多处理器系统上&#xff0c;可以真正并行运行的进程数据&#xff0c;取决于物理CPU的数目&#xff1b; 进程优先级 …

git 合并多条提交记录

我要合并多条提交记录&#xff08;合并前7条为一条&#xff09;&#xff0c;实现如下效果&#xff1a; 使用git rebase // 查看前10个commit git log -10 // 将7个commit压缩成一个commit&#xff1b;注意&#xff1a;vim编辑器 git rebase -i HEAD~4 // add已经跟踪的文件 g…

接口测试框架对比

公司计划系统的开展接口自动化测试&#xff0c;需要我这边调研一下主流的接口测试框架给后端测试&#xff08;主要测试接口&#xff09;的同事介绍一下每个框架的特定和使用方式。后端同事根据他们接口的特点提出一下需求&#xff0c;看哪个框架更适合我们。 需求 1、接口编写…

Linux 用户和权限

Linux 用户和权限 一、root 用户&#xff08;超级管理员&#xff09;1.su和exit命令2.sudo 命令3.为普通用户配置sudo认证 二、用户和用户组1.用户组管理2.用户管理3.getent 命令 三、查看权限控制信息1.认识权限控制信息 四、chmod命令五、chown命令 一、root 用户&#xff08…

怎样理解Vue单向数据流

在前端开发中&#xff0c;数据流是一个非常重要的概念。Vue.js作为一种流行的前端框架&#xff0c;采用了单向数据流的架构&#xff0c;旨在简化开发过程并提高应用的可维护性。本文将探讨Vue单向数据流的含义以及它的使用方法。 什么是单向数据流&#xff1f; 在Vue中&#…

天拓四方:边缘计算网关功能、特点与应用举例

传统的数据处理方式面临网络延迟、带宽限制和安全风险等问题。为了解决这些问题&#xff0c;边缘计算技术应运而生&#xff0c;而边缘计算网关作为其核心组件&#xff0c;正发挥着越来越重要的作用。边缘计算网关位于数据源和云数据中心之间。它具备数据采集、协议转换、数据处…

flask+vue+python跨区通勤人员健康体检预约管理系统

跨区通勤人员健康管理系统设计的目的是为用户提供体检项目等功能。 与其它应用程序相比&#xff0c;跨区通勤人员健康的设计主要面向于跨区通勤人员&#xff0c;旨在为管理员和用户提供一个跨区通勤人员健康管理系统。用户可以通过系统及时查看体检预约等。 跨区通勤人员健康管…

基于微信小程序的校园水电费管理小程序的研究与实现

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

06、全文检索 -- Solr -- Solr 全文检索之在图形界面管理 Core 的 Schema(演示对 普通字段、动态字段、拷贝字段 的添加和删除)

目录 Solr 全文检索之管理 Schema使用Web控制台管理Core的Schema3 种 字段解释&#xff1a;Field&#xff1a;普通字段Dynamic Field&#xff1a;动态字段Copy Field&#xff1a;拷贝字段 演示&#xff1a;添加 普通字段&#xff08; Field &#xff09;演示&#xff1a;添加 动…

web 技术栈有哪些?

前端技术栈&#xff1a; HTML&#xff08;超文本标记语言&#xff09;&#xff1a; 用于创建网页结构的标记语言&#xff0c;定义页面的内容和结构。 CSS&#xff08;层叠样式表&#xff09;&#xff1a; 用于设计和排版网页的样式表语言&#xff0c;负责页面的外观和样式。 …

Skywalking 应用笔记

概念 Skywalking是一款分布式的系统 性能监视工具&#xff0c;专为微服务、云原生架构和基于容器(Docker、K8s、Mesos)架构而设计。SkyWalking是一款 观察性的分析平台和应用性能管理系统&#xff0c;提供了 分布式追踪、性能指标分析、应用服务依赖分析、可视化一体化等解决方…

ChatGPT之制作短视频

引言 今天带来了如何使用 ChatGPT和剪映来制作简单的短视频教程&#xff0c;在这其中 ChatGPT的作用主要是帮我们生成文案&#xff0c;剪映的功能就是根据文案自动生成视频&#xff0c;并配上一些图片、动画、字幕和解说。 ChatGPT生成文案 首先&#xff0c;我们需要使用提示…

ChatGPT之搭建API代理服务

简介 一行Docker命令部署的 OpenAI/GPT API代理&#xff0c;支持SSE流式返回、腾讯云函数 。 项目地址&#xff1a;https://github.com/easychen/openai-api-proxy 这个项目可以自行搭建 OpenAI API 代理服务器工具&#xff0c;该项目是代理的服务器端&#xff0c;不是客户端。…

如何把vue项目打包成桌面程序 electron-builder

引入 我们想要把我们写的vue项目,打包成桌面程序&#xff0c;我们需要使用electron-builder这个库 如何使用 首先添加打包工具 vue add electron-builder 选择最新版本 下载完毕 我们可以看到我们的package.json中多了几行 electron:build&#xff1a;打包我们的可执行程序 e…