当前位置: 首页 > news >正文

【Vue3】使用vite创建Vue3工程、Vue3基本语法讲解

一、什么是Vite

Vite是新一代前端构建工具,官网地址:Vite中文网,vite的优势如下:

  • 轻量快速的热重载(HMR),能实现极速的服务启动
  • TypeScriptJSXCSS等支持开箱即用
  • 真正的按需编译,不再等待整个应用编译完成
  • webpack构建与vite对比图如下:
webpack:入口文件=》加载路由=》项目编译
vite:入口文件=》项目编译=》按需加载,访问什么加载什么

 二、搭建第一个vite项目

兼容性注意

        Vite 需要 Node.js 版本 18+ 20+。然而,有些模板需要依赖更高的 Node 版本才能正常运行,当你的包管理器发出警告时,请注意升级你的 Node 版本。

1、项目构建

npm命令:

        npm create vite@latest

yarn命令:

        yarn create vite

2、项目层级展示

说明:

  • vite项目中,index.html是项目的入口文件,在最外层目录;
  • 加载index.html文件后,vite解析<script type="module" src="/src/main.ts"></script>指向的JavaScript文件;
  • Vue3中是通过createApp(App).mount('#app')创建实例的。

3、Vue3代码初体验

        下面是一段最基础的Vue3的代代码片段

<template><div class="person"><!-- 内容可以放在这里 --><div>姓名:{{ name }}</div><div>年龄:{{ age }}</div><div>电话:{{ tel }}</div><button @click="showTel">查看联系方式</button></div>
</template><script lang="ts">
export default {name: 'person',setup() {let name = '张三'let age = '148'let tel = '1522321555'return { name, age, tel }}// data(){//   return{//     name:'张三',//     age:'148',//     tel:'1522321555'//   }// },// methods: {//   showTel() {//     alert(this.tel)//   }// },
}
</script><style scoped>
.person {background-color: skyblue;box-shadow: 0 0 10px;border-radius: 10px;/* 注意是 border-radius 不是 borde-radius */padding: 20px;
}
</style>

        注意:1、在Vue3中是可以直接使用Vue2的语法的,但是不推荐,最好不要在Vue3中写Vue2代码,维护起来很困难。

三、Vue3语法

1、Vue3的setup语法糖

        在基础Vue3语法中,我们可以看到,我们只要定义一个变量,就需要在setup中return出来,这样就很麻烦了,因此,Vue3贴心地为我们提供了一个小插件,叫做“语法糖”,用起来是相当方便的,下面介绍如何在我们的项目中集成Vue3的语法糖插件

        在Vue3中支持<script lang='ts' setup name='test'></script>中name的这种写法需要安装插件:

  1. 下载依赖:npm i vite-plugin-vue-setup-extend -D
  2. 引入插件:在vite.config.ts文件中引入 import VueSetupExtend from 'vite-plugin-vue-setup-extend'
  3. 函数调用:在vite.config.ts文件中的defineConfig函数中调用:VueSetupExtend()

        在引入Vue3的语法糖之后我们就出现了一种新的写法:

<script lang="ts" setup name="test">let name = "张三";let age = 148;let tel = "1522321555";
</script>

2、Vue3使用ref创建基本数据的响应式数据

        写在前面:ref能且只能用来定义基本数据类型

        在Vue3中,如果只按照上面的写法去定义数据,实际上数据只是静态的,那么如果我们想要响应式的数据该怎么办呢?

        在Vue3中,提供了ref函数来支持数据的响应式,如下:

import { ref } from "vue";let name = ref("三");let age = ref(148);console.log('name', name)
</script>

        ref将数据变成响应式之后,你打印出来就会发现,此时我们的数据就被ref包装成了一个RefImpl对象,如下:

        那么,使用ref包装响应式数据之后,我们在使用这个数据的时候就需要使用Object.vaule来拿到这个响应式数据了 ,如果使用的任然式原来的值,数据任然不是响应式的,我们正确地调用响应式数据就变成了这样:

<template><div class="person"><!-- 内容可以放在这里 --><div>姓名:{{ name }}</div><div>年龄:{{ age }}</div><div>电话:{{ tel }}</div><button @click="showTel">查看联系方式</button><button @click="changeNameme">修改名字</button><button @click="changeAge">修改年龄</button></div>
</template><script lang="ts" setup name="test">
import { ref } from "vue";let name = ref("三");let age = ref(148);let tel = "1522321555";console.log('name', name)function changeNameme() {name.value = ('zhang -san')console.log('name', name.value )}function changeAge() {age.value  += 1console.log('age', age.value )}
</script>
<style scoped>
.person {background-color: skyblue;box-shadow: 0 0 10px;border-radius: 10px;/* 注意是 border-radius 不是 borde-radius */padding: 20px;
}
</style>

3、Vue3使用reactive定义复杂数据类型(对象类型数据)

        写在前面:reactive能且只能用来定义对象数据类型

<template><div class="person"><h2>汽车信息:一辆{{  car.brand}}车,价值{{ car.price }}元</h2><button @click="changePrice">修改汽车价格</button><br><h2>游戏列表</h2><ul ><li v-for="item in games" :key="item.id">{{  item.name}}</li></ul><button @click="changeFirstGame">修改第一个游戏的名字</button></div>
</template><script lang="ts" setup name="test">
// 引入
import { reactive,ref } from "vue";
// 数据// 注意:
// 1、reactive只能定义复杂数据类型的响应式数据
// 2、ref不仅可以定义基本数据类型,也可以定义对象类型的响应式数据
// 3、ref定义的数据需要用.value才能拿到他的数据
// 4、ref为什么可以定义复杂数据类型呢?
//     使用ref包裹的对象类型数据通过obj.value拿到的数据也是一个Proxy对象即:ref(obj).value = reactive(obj)
let car = reactive({ brand: "奔驰", price: 100 })
let games = reactive([{id:'abcde1',name:'原神'},{id:'abcde2',name:'王者荣耀'},{id:'abcde3',name:'逆水寒'}])
console.log('car', car)// 方法
function changePrice() {car.price += 10;
}
function changeFirstGame() {games[0].name='三国志'
}
</script>
<style scoped>
</style>

4、Vue3使用ref和reactive对比

注意:
 1、reactive只能定义复杂数据类型的响应式数据
 2、ref不仅可以定义基本数据类型,也可以定义对象类型的响应式数据
 3、ref定义的数据需要用.value才能拿到他的数据
 4、ref为什么可以定义复杂数据类型呢?
     使用ref包裹的对象类型数据通过obj.value拿到的数据也是一个Proxy对象即ref(obj).value = reactive(obj)

如何使用ref和reactive呢?

【宏观角度】

1、ref用来定义:基本数据类型对象数据类型

2、reactive用来定义:对象类型数据

  • 区别
  1. ref创建的变量必须使用.value(可以使用volar插件自动添加.value)
    • 配置volar
      • 应用商店下载TypeScript Vue Plugin (Volar) —》“管理”—》“设置”—》“扩展”—》“volar”—》“Auto Insert: Dot Value”勾选

  • reactive的局限性

reactive重新分配一个新的对象,会失去响应式(可以使用Object.assign去整体替换)//reactive的局限性

let car = reactive({ brand: "奔驰", price: 100 });function changeCar() {
//这样 reactive就会失去响应式car = { brand: "雅迪", price: 10 };
//给reactive重新赋值需要这样写:Object.assign(car,{ brand: "雅迪", price: 10 })
}

使用ref定义对象类型数据则不会出现这种情况

let car = ref({ brand: "奔驰", price: 100 });function changeCar() {car.value = { brand: "雅迪", price: 10 };
}

【使用原则】

1、若需要一个基本类型的响应式数据,必须用ref

2、若需要一个响应式对象,层级不深,ref、reactive都可以;

3、若需要一个响应式对象,且层级较深,推荐使用reactive(表单数据)。

5、Vue3使用torefs和toref对比

        相同点:torefs和toref都是将一个响应式对象种的东西解构出来,而同时让解构出来的数据具备响应式的能力。

        不同点:torefs能够结构整个对象torefs(Object),而toref只能解构一个属性toref(Object,'name')

6、Vue3的计算属性—computed

        (1)只要计算属性所依赖的数据发生了变化,他就会重新计算(计算属性是有缓存的)

        (2)要想改变计算属性的值,需要用get()和set()

<template><div class="person">姓:<input type="text" v-model="firstName"><br>名:<input type="text"  v-model="lastName"><br>全名:<span>{{fullName}}</span><button @click="changeFullName">改变名字</button></div>
</template><script lang="ts" setup name="test">
// 引入
import { ref, computed } from "vue";
let firstName = ref("张");
let lastName = ref("三");
console.log("firstName", firstName.value);// 计算属性:只要计算属性所依赖的数据发生了变化,他就会重新计算(计算属性是有缓存的)
// 注意:这样定义的计算属性,只能读不能改
// let fullName = computed(() => {
//   return (
//     firstName.value.slice(0, 1).toUpperCase() + firstName.value.slice(1) + lastName.value
//   );
// });// 注意:这样定义的计算属性,可读可写
let fullName = computed({get() {return (firstName.value.slice(0, 1).toUpperCase() +firstName.value.slice(1) +lastName.value);},set(val) {const [str1, str2] = val.split("-");firstName.value = str1;lastName.value = str2;console.log("set");console.log("val", val);},
});function changeFullName() {fullName.value = "李-四";
}
</script>
<style scoped>
</style>

7、Vue3的监听属性—watch

  • 作用:监视数据的变化(和Vue2中的watch作用一致)
  • 特点:Vue3中的watch只能监视一下四种数据:

1、 ref定义的数据

2、reactive定义的数据

3、函数返回一个值(getter函数),通俗来讲就是一个带返回值的函数

4、一个包含上述内容的数组

在Vue3中使用watch的时候,通常会遇到以下几种情况:

情况一:监听ref定义的【基本类型】数据

        监听ref定义的【基本类型】数据:直接写数据名即可,监视的是其value值的改变

① 先引入watch

② 监听【ref】定义的【基本类型】数据

③ 解除监视

注意:监听ref定义的基本类型数据的时候,不需要.value

<template><div><h1>1、监听ref定义的【基本类型】数据</h1><h2>当前求和为:{{ sum }}</h2><button @click="handleClick">点我sum+1</button></div>
</template><script setup lang="ts">
// 1、先引入watch
import { ref,watch } from "vue";
// 定义数据
let sum = ref(0)
// 方法
function handleClick() {sum.value+=1 
}
// 2、监听【ref】定义的【基本类型】数据
// watch('鉴定对象',监听函数)
const stopWatch = watch(sum,(newValue,oldValue)=>{console.log('sum变化了',newValue,oldValue)if(newValue>10){
//3、停止监听stopWatch()}
})
</script>
情况二:监听ref定义的【对象类型】数据

        监听ref定义的【对象类型】数据:直接写数据名,监听的是对象的【地址值】,若想监听对象内部的数据,要手动开启深度监视

面试题:

1、watch的参数?        

  • 第一个参数是【被监视的数据】
  • 第二个参数是【监视的回调】
  • 第三个参数是【配置对象(deep,immediate....)】

2、watch监听的数据,什么时候newValue和oldValue是一样的?

  • 若修改的是ref定义的对象中的属性,newValueoldValue都是新值,因为他们是同一个对象;
  • 若修改的是整个ref的对象,newValue是新值,oldValue是旧值,因为不是同一个对象了。
 情况三:监听reactive定义的【对象类型】数据

        监听【reactive】定义的【对象类型】数据时,watch默认开启深度监听,这种深度监听是无法关闭的(隐式创建深度监听)

<template><div><h2>姓名:{{ person.name }}</h2><h2>年龄:{{ person.age }}</h2><button @click="handleName">修改名字</button><button @click="handleAge">修改年龄</button><button @click="changePerson">修改个人</button></div>
</template><script setup lang="ts" name="action3">
import { reactive, watch } from "vue";let person = reactive({name: "张三",age: 20,
});function handleName(params: any) {console.log("params", params);person.name += "~";
}
// 修改年龄
function handleAge(params: any) {console.log("params", params);person.age += 1;
}
// 修改个人
function changePerson(params: any) {console.log("params", params);Object.assign(person, { name: "李四", age: 30 });
}// 监听【reactive】定义的【对象类型】数据
// 1、watch默认开启深度监听,这种深度监听是没法关闭的(隐式创建深度监听)watch(person, (newValue, oldValue) => {console.log("person变化了", newValue, oldValue);
});
</script>

知识点:
   ref定义的对象类型数据修改 =》 person.value = {name:'李四',age:60}
   reactive定义的对象类型数据修改 =》 Object.assign(person,{name:'李四',age:30})

  1. 这样修改reactive定义的数据,是没有办法改变他的值的,在Vue3中如果要改变reactive定义的对象类型数据,必须用Object.assign
  2. 但是,用ref定义的对象类型数据却可以直接person.value = {name:'李四',age:60} 进行修改

本质上:ref修改数据,是将数据重新赋值;reactive修改数据,是将原数据改变
原因:官方文档指出,reactive定义的对象类型数据不可直接修改

情况四:监听ref或reactive定义的【对象类型】数组中的某个属性

        1、若该属性不是【对象类型】,需要写成函数形式;

        2、若该属性值依然是【对象类型】,可直接编辑,也可以写成函数,不过建议写成函数

        总的来说:监视的要是对象里的属性,那么最好写成一个getter函数式,注意点:若是对象监视的地址值,需要关注对象内部,需要手动开启深度监听 。

<template><div class="person"><h2>姓名:{{ person.name }}</h2><h2>年龄:{{ person.age }}</h2><h2>汽车:{{ person.car.c1 }}、{{ person.car.c2 }}</h2><button @click="changeName">修改名字</button><button @click="changeAge">修改年龄</button><button @click="changeC1">修改第一台车</button><button @click="changeC2">修改第二台车</button><button @click="changeCar">修改车</button></div>
</template>
<script setup lang="ts" name="action3">
import { reactive, watch } from "vue";// 数据
let person = reactive({name: '张三',age: 20,car: {c1: '奔驰',c2: '拖拉机'}
})
// 方法
function changeName(params: type) {person.name += '~'
}
function changeAge(params: type) {person.age += 1
}
function changeC1(params: type) {person.car.c1 = '奥迪'
}
function changeC2(params: type) {person.car.c2 = '拖油塔'
}
function changeCar(params: type) {person.car = {c1: '雅迪',c2: '爱玛'}
}// 只监视某个基本类型数据(要将其组装成一个带返回值的函数)
// ★若监听的属性不是【对象类型】,需要写成函数形式;
// 完整写法:
watch(() => { return person.name }, (newValue, oldValue) => {console.log('person.name变化了!', newValue, oldValue)
})
// 简写:
watch(() => person.name, (newValue, oldValue) => {console.log('person.name变化了!', newValue, oldValue)
})
/*******************************************************/
// 只监听某个对象类型数据
// ★若该属性值依然是【对象类型】,可直接编辑,也可以写成函数,不过建议写成函数
//情况一: 只能监听到对象中每一个属性的变化情况,无法监听整个对象的变化情况
watch(person.car,(newValue, oldValue)=>{console.log('person.car变化了!', newValue, oldValue)
})
// 情况二:只能监听整个对象的变化,其中的属性发生变化的时候,无法监听到
watch(()=>person.car,(newValue, oldValue)=>{console.log('person.car变化了!', newValue, oldValue)
})
// 情况三:(完美方案)既能监听每一个属性的变化,也能监听到整个对象的变化
watch(()=>person.car,(newValue, oldValue)=>{console.log('person.car变化了!', newValue, oldValue)
},{deep:true})
</script>
情况五:监听上述的多个数据

1、使用watch监听多个数据

<template><div class="person"><h2>姓名:{{ person.name }}</h2><h2>汽车:{{ person.car.c1 }}、{{ person.car.c2 }}</h2><button @click="changeName">修改名字</button><button @click="changeC1">修改第一台车</button><button @click="changeCar">修改车</button></div>
</template>
<script setup lang="ts" name="action5">
import { reactive, watch } from "vue";// 数据
let person = reactive({name: '张三',age: 20,car: {c1: '奔驰',c2: '拖拉机'}
})
// 方法
function changeName(params: type) {person.name += '~'
}
function changeC1(params: type) {person.car.c1 = '奥迪'
}
function changeCar(params: type) {person.car = {c1: '雅迪',c2: '爱玛'}
}
// 监听上述多个数据的变化
watch([()=>person.name,()=>person.car,],(newValue,oldValue)=>{console.log('多个数据发生变化',newValue,oldValue)
},{deep:true})
</script>

2、使用watchEffect

        官网定义:立即运行一个函数,同时响应式地追踪其依赖,并在依赖更改时重新执行该函数。

面试题:【watch】和【watchEffect】对比

  • 都能监听响应式数据的变化,不同的时监听方式的不同
  • watch:要明确指出监听的数据
  • watchEffect:不用明确指出监听的数据(函数中用到哪些属性,就自动监听哪些属性)

        如何使用watchEffect?

<template><div><div>需求:当水温达到60度,或水位达到80cm时,给服务器发请求</div><h2>当前水温:{{ temp }}℃</h2><h2>当前水温:{{ height }}cm</h2><button @click="changeTemp">水温+10</button><button @click="changeHeight">水位+1</button></div>
</template>
<script lang="ts" setup>
import { ref, watch, watchEffect } from "vue";
// 数据
let temp = ref(10);
let height = ref(0);
// 方法
function changeTemp(params: type) {temp.value += 10;
}
function changeHeight(params: type) {height.value += 10;
}
// 使用watchEffect监听
watchEffect(()=>{if (temp.value>=60 || height.value) {console.log('向服务器发送请求')}
})
</script>

8、标签的ref属性

作用:用于注册模板引用

  • 用在不同DOM标签上,获取的时DOM节点
  • 用在组件标签上,获取的组件实例

用法:

  1. 父组件中,将ref属性绑定到子组件上,并且需要定义绑定的ref属性
  2. 子组件中,通过defineExpose方法,将子组件中的参数/方法暴露给父组件使用 

代码示例:

父组件

<template><div><h1>中国</h1><h2 id="address">西安</h2><h3 ref="title1">小张快跑。</h3><button @click="showLog">点我打印元素</button><son ref="sonRef"/><button @click="showSonLog">点我获取子组件的属性</button></div>
</template>
<script lang="ts" setup>
import son from "./son.vue";
import { ref } from "vue";// 创建一个title1参数, 用于存储ref标记的内容
let title1 = ref<HTMLElement | null>(null);
let sonRef = ref<HTMLElement | null>(null);
const showLog = () => {// 使用原生方法,弊端: 如果全局中出现同名ID, 这样获取的值时混乱的console.log('地址:', document.querySelector("#address")?.innerHTML);// 使用ref方法, 特点: 如果全局中出现同名ID, 全局不受影响console.log('名字', title1.value?.innerHTML); // 防止空值访问
};
const showSonLog =()=>{// 这样只能获取到组件的实,然而并不能获取到组件中的值和方法,这是vue3的一种保护措施console.log('子组件实例', sonRef.value)// 只有子组件通[defineExpose]暴露参数/方法后,父组件才能直接用console.log('子组件中的参数', sonRef.value.a)
}
</script>

 子组件

<template><div>子组件</div>
</template>
<script lang="ts" setup>
import { ref,defineExpose } from "vue";let a = ref(0)
let b = ref(1)
let c = ref(2)defineExpose({a})
</script><style lang="scss" scoped></style>

相关文章:

【Vue3】使用vite创建Vue3工程、Vue3基本语法讲解

一、什么是Vite Vite是新一代前端构建工具&#xff0c;官网地址&#xff1a;Vite中文网&#xff0c;vite的优势如下&#xff1a; 轻量快速的热重载&#xff08;HMR&#xff09;&#xff0c;能实现极速的服务启动对TypeScript、JSX、CSS等支持开箱即用真正的按需编译&#xff…...

专题二:二叉树的深度优先搜索

以leetcode2331题为例 题目分析&#xff1a; 以第一个示例为例 算法原理分析&#xff1a; 从宏观角度&#xff0c;也就是我的算法之回溯的第一篇 我们发现我们在研究示例的时候&#xff0c;必须从下往上推 也就是我在研究一个结点是true还是false的时候&#xff0c;必须…...

Termius ssh连接服务器 vim打开的文件无法复制问题

你的问题是&#xff1a; • 在 Termius (macOS) SSH 连接到 VMware Ubuntu&#xff0c;使用 vim 打开 .cpp 文件时&#xff0c;可以复制文本&#xff1b; • 但在 Windows 10 上 SSH 到 VMware 的 Red Hat 6.4 时&#xff0c;复制操作无效。 ⸻ &#x1f3af; 初步分析 复制…...

搭建大数据学习的平台

一、基础环境准备 1. 硬件配置 物理机&#xff1a;建议 16GB 内存以上&#xff0c;500GB 硬盘&#xff0c;多核 CPU虚拟机&#xff1a;至少 3 台&#xff08;1 主 2 从&#xff09;&#xff0c;每台 4GB 内存&#xff0c;50GB 硬盘 2. 操作系统 Ubuntu 20.04 LTS 或 CentOS…...

Matlab 模糊控制节水洗衣机模型

1、内容简介 Matlab 232-模糊控制节水洗衣机模型 可以交流、咨询、答疑 2、内容说明 略 3、仿真分析 略 4、参考论文 略...

如何找正常运行虚拟机

1.新建虚拟机。Linux centos7&#xff0c;给虚拟机改个名字不要放在c盘 2.安装操作系统。cd/dvd->2009.iso 启动虚拟机...

python二手书交易管理系统

目录 技术栈介绍具体实现截图系统设计研究方法&#xff1a;设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理&#xff0c;难度适中&#xf…...

使用本地部署的 LLaMA 3 模型进行中文对话生成

以下程序调用本地部署的 LLaMA3 模型进行多轮对话生成&#xff0c;通过 Hugging Face Transformers API 加载、预处理、生成并输出最终回答。 程序用的是 Chat 模型格式&#xff08;如 LLaMA3 Instruct 模型&#xff09;&#xff0c;遵循 ChatML 模板&#xff0c;并使用 apply…...

C++编程练习,认识面向对象权限,如何进行封装

#include <iostream> #include <string> using namespace std; /* 银行的账户是一个模板&#xff0c;是一个类&#xff0c;有存款人信息和账户额度&#xff0c;而具体的存款人视为一个对象&#xff0c; 一个对象不能私自修改账户额度&#xff0c;需要通过一个操作流…...

A Survey of Learning from Rewards:从训练到应用的全面剖析

A Survey of Learning from Rewards&#xff1a;从训练到应用的全面剖析 你知道大语言模型&#xff08;LLMs&#xff09;如何通过奖励学习变得更智能吗&#xff1f;这篇论文将带你深入探索。从克服预训练局限的新范式&#xff0c;到训练、推理各阶段的策略&#xff0c;再到广泛…...

电脑端音乐播放器推荐:提升你的听歌体验!

在快节奏的职场环境中&#xff0c;许多上班族都喜欢用音乐为工作时光增添色彩。今天要分享的这款音乐工具&#xff0c;或许能为你的办公时光带来意想不到的惊喜。 一、软件介绍-澎湃 澎湃音乐看似是个普通的播放器&#xff0c;实则藏着强大的资源整合能力。左侧功能栏清晰陈列着…...

小刚说C语言刷题—1149 - 回文数个数

1.题目描述 一个正整数&#xff0c;正读和反读都相同的数为回文数。 例如 22&#xff0c; 131&#xff0c; 2442 &#xff0c; 37073&#xff0c; 66&#xff0c;…… 所有 11位数都是回文数。 给出一个正整数 n &#xff08; 1≤n≤10000 &#xff09;&#xff0c;求出 1,2…...

基于SpringBoot的博客系统测试报告

一、编写目的 本报告为博客系统测试报告&#xff0c;本项目模拟了csdn&#xff0c;实现了包括了用户登录&#xff0c;发布博客文章&#xff0c;查看博客等功能。 二、项目背景 博客系统采用前后端分离的方法来实现&#xff0c;同时使用了数据库来存储相关的数据&#xff0c…...

Koa知识框架

一、核心概念 1. 基本特点 由 Express 原班人马开发的下一代 Node.js Web 框架 基于中间件的洋葱圈模型 轻量级核心&#xff08;仅约 600 行代码&#xff09; 完全使用 async/await 异步流程控制 没有内置任何中间件&#xff0c;高度可定制 2. 核心对象 Application (Ko…...

React Native踩坑实录:解决NativeBase Radio组件在Android上的兼容性问题

React Native踩坑实录&#xff1a;解决NativeBase Radio组件在Android上的兼容性问题 问题背景 在最近的React Native项目开发中&#xff0c;我们的应用在iOS设备上运行良好&#xff0c;但当部署到Android设备时&#xff0c;进入语言设置和隐私设置页面后应用崩溃。我们遇到了…...

RCE联系

过滤 绕过空格 ● 进制绕过 题目练习 数字rce 使用$0执行bash&#xff0c;<<<将后面的字符串传递给左边的命令。 例如&#xff1a; <?php highlight_file(__FILE__); function waf($cmd) { $whiteList [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, \\, \, $, <]; $cmd_ch…...

区块链大纲笔记

中心化出现的原因是由于网络的形成&#xff08;不然就孤立了&#xff0c;这显然不符合现实&#xff0c;如&#xff0c;社会&#xff0c;计算机网路&#xff09;&#xff0c;接着由于网络中结点能力一般不对等同时为了便于管理等一系列问题&#xff0c;导致中心化网络的出现。&a…...

SQL:JOIN 进阶

目录 JOIN 是什么&#xff1f; &#x1f539;OUTER JOIN&#xff08;外连接&#xff09; 外连接的分类 外连接与内连接的区别 &#x1f539;USING 子句 语法结构 和 ON 的对比 &#x1f4d8;USING 的内部逻辑 &#x1f9e9; 多个字段的 USING USING 的 SELECT 特性&a…...

SATA—Link层状态机

一、概述 Link层的状态机大致可以分为五类&#xff1a; 链路层空闲状态机通信异常处理状态机链路层发送状态机链路层接收状态机链路层电源管理下的状态机 二、链路层空闲状态机 链路层空闲状态机共包含两个状态L_IDLE、L_SyncEscape&#xff0c;每个状态下的处理机制与条状…...

12.2.2 allocator类

allocator类将分配内存空间、调用构造函数、调用析构函数、释放内存空间这4部分操作分开&#xff0c;全部交给程序员来执行&#xff0c;不像new和delete #include <iostream> #include <string>int main() {const int n 10;std::allocator<std::string> al…...

Qwen:Qwen3,R1 在 Text2SQL 效果评估

【对比模型】 Qwen3 235B-A22B&#xff08;2350亿总参数&#xff0c;220亿激活参数&#xff09;&#xff0c;32B&#xff0c;30B-A3B&#xff1b;QwQ 32B&#xff08;推理模型&#xff09;DeepSeek-R1 671B&#xff08;满血版&#xff09;&#xff08;推理模型&#xff09; 1&a…...

Egg.js知识框架

一、Egg.js 核心概念 1. Egg.js 简介 基于 Koa 的企业级 Node.js 框架&#xff08;阿里开源&#xff09; 约定优于配置&#xff08;Convention over Configuration&#xff09; 插件化架构&#xff0c;内置多进程管理、日志、安全等能力 适合中大型企业应用&#xff0c;提供…...

latex控制表格宽度,不要超出页面

字体控制 控制表格的字体&#xff0c;一般使用 footnotesize &#xff0c;neurips 使用的就是这个大小 列宽距控制 默认列宽距是 6pt &#xff0c;可以人工调节成为 5pt&#xff0c;不影响字体&#xff0c;比较不影响可读性 % 对于 table* 环境, [htbp] 通常比 [h] 或 [h!]…...

Linux进程管理

程序、进程、服务 程序 program 安装包&#xff0c;未运行的代码&#xff0c;APP 存放在磁盘上 进程 process 已运行程序、命令、服务&#xff0c;一个程序可以运行多个进程、父进程启动子进程 运行在内存中 服务 service 一直运行的进程&#xff0c;也叫做守护进程&…...

[springboot]SSM日期数据转换易见问题

日期数据的形式有多种&#xff0c;如2025-05-12 14:46:50、2025.05.12 14:46&#xff0c;可以没有年只有月日...等等。 在SSM项目中&#xff0c;前后端传递日期数据时往往需要统一格式&#xff0c;不然会报数据类型转换异常。 在controller层中用实体类实例对象接收前端服务器传…...

数字IC后端培训教程之数字后端项目典型案例分析

今天给大家分享下最近小编帮助学员解决的几个经典数字IC后端项目问题。希望能够对大家的学习和工作有所帮助。 数字IC后端项目典型问题之后端实战项目问题记录&#xff08;2025.04.24&#xff09; 数字IC后端设计实现培训教程&#xff08;整理版&#xff09; Q1: 老师好&…...

数字ic后端设计从入门到精通4(含fusion compiler, tcl教学)CMOS VLSI Design

Layout Design Rules 一、什么是 Layout Design Rules&#xff1f; 布局设计规则是一套用于指导芯片物理设计的几何约束条件&#xff0c;确保设计可以在特定制造工艺下被正确制造。这些规则通常由代工厂&#xff08;foundry&#xff09;提供&#xff0c;规定了最小线宽、间距、…...

服务器带宽基础知识

服务器带宽基础知识详解 一、带宽的定义与基本概念 服务器带宽&#xff08;Bandwidth&#xff09;是指服务器与互联网之间在单位时间内传输数据的能力&#xff0c;通常以 Mbps&#xff08;兆比特每秒&#xff09; 或 Gbps&#xff08;吉比特每秒&#xff09; 为单位衡量。它决…...

算法-单调栈

739. 每日温度 - 力扣&#xff08;LeetCode&#xff09; 原理&#xff1a;739. 每日温度 - 力扣&#xff08;LeetCode&#xff09; class Solution { public:vector<int> dailyTemperatures(vector<int>& temperatures) {stack<int>sta;int ntemperatu…...

大核极坐标码

大核极性码&#xff08;ℓ>2&#xff09;的SC解码操作与原始极性码相似。迭代地&#xff0c;解码方程可以表示为&#xff1a; 这是给定信道输出的路径的概率。 虽然这些操作类似于传统的极坐标码&#xff0c;但迭代计算概率的复杂性相对于ℓ 作为&#xff0c;这使得它对于非…...

如何避免 JavaScript 中常见的闭包陷阱?

文章目录 1. 引言2. 什么是闭包&#xff1f;3. 常见的闭包陷阱及解决方案3.1 循环中的闭包陷阱3.2 内存泄漏3.3 意外的全局变量3.4 React 中的闭包陷阱 4. 总结 1. 引言 闭包&#xff08;Closure&#xff09;是 JavaScript 中一个强大而常用的特性&#xff0c;它允许函数访问其…...

免费多线程下载工具

先放下载链接&#xff1a;https://tool.nineya.com/s/1ir25buco Free Download Manager&#xff0c;简称“FDM”&#xff0c;是一款多线程下载工具&#xff0c;支持多端使用哦&#xff0c;像Windows、mac Os、Linux、浏览器插件以及安卓端都涵盖在内&#xff0c;这些版本这里都…...

Aware和InitializingBean接口以及@Autowired注解失效分析

Aware 接口用于注入一些与容器相关信息&#xff0c;例如&#xff1a; ​ a. BeanNameAware 注入 Bean 的名字 ​ b. BeanFactoryAware 注入 BeanFactory 容器 ​ c. ApplicationContextAware 注入 ApplicationContext 容器 ​ d. EmbeddedValueResolverAware 注入 解析器&a…...

【NextPilot日志移植】日志写入流程

&#x1f4dd; 文件后端日志写入流程详解 当后端选择文件时&#xff0c;日志写入过程主要涉及 LogWriter 和 LogWriterFile 类的协作。以下是详细的日志写入过程解释及涉及的代码&#xff1a; 1. LogWriter 类初始化 在 LogWriter 类的构造函数中&#xff0c;如果配置的后端…...

OpenCV直方图与直方图均衡化

一、图像直方图基础 1. 什么是图像直方图&#xff1f; 图像直方图是图像处理中最基本且重要的统计工具之一&#xff0c;它用图形化的方式表示图像中像素强度的分布情况。对于数字图像&#xff0c;直方图描述了每个可能的像素强度值&#xff08;0-255&#xff09;在图像中出现…...

Babel进阶:如何自定义插件?

Babel 是一个非常流行的 JavaScript 编译器&#xff0c;下面我们将从零到一编写一个 babel 箭头函数语法转换插件&#xff0c;掌握 babel 插件设计思路与编写规范&#xff0c;需求很简单就是将箭头函数转换为普通函数。 const test ()>{console.log("Hello World!&qu…...

C++中类中const知识应用详解

下面将从**const 成员**、const 成员函数、const 对象、mutable、constexpr 等方面&#xff0c;逐一详解 C 类中常见的 const 用法及注意事项&#xff0c;并配合示例。 一、const 数据成员 必须在初始化列表中初始化 class A {const int x; // const 成员 public:A(int v) :…...

LeetCode 513 找树左下角的值 LeetCode 112 路径总和 LeetCode106 从中序与后序遍历序列构造二叉树

LeetCode 513 找树左下角的值 迭代法——层序遍历 思路&#xff1a;对树进行层序遍历操作&#xff0c;层序遍历完后&#xff0c;输出树最后一层的第一个节点。 # Definition for a binary tree node. # class TreeNode(object): # def __init__(self, val0, leftNone, r…...

电脑端实用软件合集:土拨鼠+Rufus+实时网速监控工具

朋友们好&#xff0c;我是李师傅&#xff01;今天带来三款让人直呼"真香"的电脑工具&#xff0c;它们就像武林高手各怀绝技&#xff0c;保证让你工作效率翻倍&#xff01; 1Tuboshu&#xff08;电脑&#xff09; 最近发现一款神奇工具——Tuboshu&#xff08;发音类…...

杨校老师项目之基于SSM与JSP的鲜花销售系统-【成品设计含文档】

基于SSMJSP鲜花商城系统 随着电子商务的快速发展&#xff0c;鲜花在线销售已成为一种重要的消费模式。本文设计并实现了一个基于JSP技术的鲜花销售管理系统&#xff0c;采用B/S架构&#xff0c;使用SSM框架进行开发&#xff0c;并结合Maven进行项目依赖管理。系统分为前台用户模…...

linux服务器免密脚本分享

#!/bin/bash set -euo pipefail# 基础环境配置 setenforce 0 >/dev/null 2>&1 || true sed -i "s/SELINUXenforcing/SELINUXdisabled/" /etc/selinux/config systemctl stop firewalld >/dev/null 2>&1 || true systemctl disable firewalld >…...

STM32实现循环队列

1. 循环队列的核心结构设计 ​数据结构定义&#xff1a;通常使用结构体封装队列的指针、长度及缓冲区。例如&#xff1a; typedef struct {u16 Head; // 队头指针u16 Tail; // 队尾指针u16 Length; // 当前队列长度u8 Rsv_DAT[50]; // 缓冲区数组 } ringbuff_t; 其中…...

matlab simulink双边反激式变压器锂离子电池均衡系统,双目标均衡策略,仿真模型,提高均衡速度38%

双边反激式变压器锂离子电池均衡系统&#xff0c;双目标均衡策略 锂离子电池均衡系统综述 引言 电池均衡管理系统(Battery Balancing Management System, BBMS)是电池管理系统(BMS)的核心组成部分&#xff0c;主要用于解决电池组中单体电池间的不一致性问题。随着电动汽车、储能…...

数据库笔记(1)

文章目录 1.SQL的通用语法2.四类SQL语句2.1DDL语句2.2.1数据库操作2.1.2表操作 2.2DML语句2.2.1添加数据(INSERT)2.2.2修改数据(UPDATE)2.2.3删除数据(DELETE) 2.3DQL语句2.3.1DQL语法2.3.2基本查询2.3.3条件查询2.3.4分组查询2.3.5排序查询2.3.6分页查询2.3.7DQL语句的执行顺序…...

深入掌握CSS定位:构建精密布局的核心技术

一、定位的定义 定位&#xff08;Positioning&#xff09;是CSS中用于控制元素在网页中的具体位置的一种机制。通过定位&#xff0c;可以将元素放置在页面的任意位置&#xff0c;并控制其与其他元素的层叠关系。 二、定位的特点与作用 自由摆放位置&#xff1a; 允许元素摆放…...

使用达梦数据库官方管理工具SQLark导入与导出数据库表

SQLark 是达梦数据官方自主研发的、一款面向信创应用开发者的数据库开发和管理工具。只需简单注册&#xff0c;即可永久免费使用其客户端功能。该工具支持连接达梦、Oracle、MySQL 等多种数据库&#xff0c;为开发者提供了便捷的跨平台操作体验。通过访问官网 www.sqlark.com&a…...

Linux系统管理与编程19:自动部署dns

兰生幽谷&#xff0c;不为莫服而不芳&#xff1b; 君子行义&#xff0c;不为莫知而止休。 #!/bin/bash #----------------------------------------------------------- #前提条件&#xff1a;准备好虚拟机&#xff0c;①外网内网畅通&#xff0c;②yum源搭建好 # File Name: …...

JavaScript高级进阶(七)

this对象 想知道this对象是什么&#xff0c;我们先来看一段简单的小代码: <style> div{ width: 200px; height: 200px; background-color: skyblue; } </style> </head> <body> <div…...

前端面试每日三题 - Day 32

这是我为准备前端/全栈开发工程师面试整理的第32天每日三题练习&#xff1a; ✅ 题目1&#xff1a;Electron主流架构模式深度解析 核心架构模式对比 模式优点缺点适用场景单一窗口模式开发简单、资源占用低功能扩展受限小型工具类应用多窗口模式模块解耦、独立运行进程管理复…...

MySQL全量,增量备份与恢复

目录 一.MySQL数据库备份概述 1.数据备份的重要性 2.数据库备份类型 3.常见的备份方法 二&#xff1a;数据库完全备份操作 1.物理冷备份与恢复 2.mysqldump 备份与恢复 3.MySQL增量备份与恢复 3.1MySQL增量恢复 3.2MySQL备份案例 三&#xff1a;定制企业备份策略思路…...