第四章:前端框架Vue基础入门

news2024/11/24 12:57:00

文章目录

  • 一、Vue框架概述
    • 1.1 声明响应式的数据
  • 二、Vue内置指令
    • 2.1、条件渲染指令v-if/v-show
    • 2.2 v-for: 列表渲染
    • 2.3、v-text/v-html 模板指令
    • 2.4 v-on:事件监听器
    • 2.6 动态绑定v-bind
    • 2.7 v-model表单元素值绑定
  • 三、计算属性与监视
    • 3.1 计算属性computed
    • 3.2 watch侦听器
    • 3.3 watch、watchEffect、computed区别
  • 四、高级特性
    • 4.1 组件
      • 4.1.1 创建组件
      • 4.1.2 组件通信
    • 4.2 生命周期
  • 六、脚手架案例
    • 6.1 vue-router:前端路由
    • 6.2 axios:接口请求

本章学习目标:

  • 了解Vue框架架构思想
  • 掌握Vue核心指令
  • 掌握计算属性与监视
  • 掌握组件化开发模式

一、Vue框架概述

  • 官方文档:https://cn.vuejs.org/guide/introduction.html.
  • 文档可选择使用optionsAPI(选项式API)阅读,或者CompositionApi(组合式API)阅读。选项式API更适合平滑从vue2过渡,以下示例均以Compositions API方式编写。
  • 如何使用compositions API? : 在.vue文件的script标签上,添加setup属性则被识别为使用compositionsAPI。不添加则默认为optionsAPI方式
    在这里插入图片描述
<script setup>
// 组合式API写法
</script>

<script>
// 选项式写法
export default {
  components:{},
  data(){ return {}},
  methods:{},
}
</script>

1、VUE的优势:

  • 渐进式框架,没有强主张。
  • 只是个轻量视图,只做了自己该做的事。
  • 渐进式:数据绑定——》路由控制——》组件开发——》数据共享

2、Vue是什么?

  • Vue.js (读音 /vju:/,类似于view) 是一套构建用户界面的渐进式框架。
  • 与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计
  • 轻量级MVVM框架
  • 通过简单的API,提供高效的数据绑定和灵活的组件系统

3、VUE的引入步骤(三种方式)

  1. 直接下载vue.js的库文件,使用script标记引入到页面中。
  2. 使用cdn进行引入,网络上的vue。
  3. 使用npm进行安装。

4、创建一个vue应用

  • 本节以vue官方脚架方式来进行demo演示。
  • vue3推荐使用create-vue来创建基于 Vite 的新项目。
  • 脚手架地址:https://github.com/vuejs/create-vue
# 1、安装项目模板
npm create vue@latest
# 2、demo用,对话内容都选No
# 3、进入创建好的文件
cd vue-project
# 4、安装依赖
npm install
# 5、启动项目
npm run dev   
  • 脚手架安装自定义选项
    在这里插入图片描述

  • 创建后生成项目目录结构如下:
    在这里插入图片描述

  • 成功启动后,以浏览器中访问:http://127.0.0.1:5173/
    在这里插入图片描述

打开项目后

  • 打开App .vue(入口模板文件)
  • 打开components目录,里面的所有.vue文件即为组件
  • .vue文件即为vue模板组件,主要分为三大块script(交互脚本), template(HTML),style(样式)
  • 清除内容,只留下script,template,style标签,看页面如何变化
<template>
<h1>hello world!</h1>
</template>

<script setup>
console.log("hello world!")
</script>

<style scoped>
h1{
	color:red;
}
</style>

1.1 声明响应式的数据

  • 在vue3中,新增了ref,reactive函数来定义一个响应式数据
  • ref(): 接收参数作为初始值,并将参数包装为具有响应性的ref对象返回,通过返回的ref对象的.value属性来取值,在选项式API的setup()函数或在带setup属性的script标签中定义使用
  • reactive() : 直接定义一个具有响应性的对象(ref是将数据包装为特殊ref对象)
    • reactive:只能用于定义对象类型 (对象、数组和如 Map、Set 这样的集合类型)。不支持原始类型
    • 不能替换整个被定义的对象,这样会导致响应性连接丢失
    • reactive定义的响应式对象,不能使用解构取值,也会导致响应性连接丢失
<template>
  <div>
    <p>定义的ref值:{{ refVal }}</p>
    <p>定义的reactive值:{{ obj.count }}</p>
  </div>
</template>

<script setup>
import {ref,reactive} from 'vue'
let refVal = ref("hello")
// 在template模板中会用ref对象的值时不需要.value,但在script中需要
console.log(refVal.value)

let obj = reactive({
  count:1
})
</script>

<style scoped>
</style>

二、Vue内置指令

以下demo以vue3的composition API为例使用

2.1、条件渲染指令v-if/v-show

  • v-if: 条件渲染,显示与隐藏(布尔值)
    • v-if: 基于表达式值的真假性,来条件性地渲染元素或者模板片段
    • v-if-else:与v-if搭配使用,实现链式调用
    • v-else:与v-if搭配使用,实现链式调用
    • 注意:当 v-if 元素被触发,元素及其所包含的指令/组件都会销毁和重构。如果初始条件是假,那么其内部的内容根本都不会被渲染。
  • v-show:条件渲染
    • 原理:v-show 通过设置内联样式的 display CSS 属性来工作,当元素可见时将使用初始 display 值。

v-if与v-show的区别?
v-if通过值的真假来控制元素是否被渲染来实现显隐,而v-show通过css的display属性来控制实现显示与隐藏。v-if元素每一次触发都会引起重构。

<template>
  <div>
    <div v-if="type === 'A'">A</div>
    <div v-else-if="type === 'B'">B</div>
    <div v-else-if="type === 'C'">C</div>
    <div v-else>Not A/B/C</div>
  </div>
</template>

<script setup>
// 声明一个变量
let type ='B'
</script>
<style scoped>
</style>

2.2 v-for: 列表渲染

  • 基于原始数据多次渲染元素或模板块
  • 支持遍历的原始数据可以是:Array | Object | number | string | Iterable
<template>
  <div>
    <!-- 遍历数组 -->
   <div>
    <span v-for="(item,index) in arr" :key="index">{{item}},</span>
   </div>
   <!-- 遍历对象 -->
   <div>
    <span v-for="(value,key) in obj" :key="key">{{key}}-{{value}},</span>
   </div>
  </div>
</template>

<script setup>
 let arr = ['apple','banana','peach','cherry']
 let obj={
  "name":"张三",
  "age":"18",
  "sex":"男"
 }
</script>
<style scoped>
</style>

2.3、v-text/v-html 模板指令

  • v-text: 更新元素的文本内容(类似DOM API中的innerText)
  • v-html:更新元素的 innerHTML。(类似innerHTML)
<template>
  <div>
    <div v-text="textStr"></div>
    <div v-html="htmlStr"></div>
  </div>
</template>

<script setup>
  let textStr = "这是一段文本,html内容不会被解析为html.如<h1>h1标签</h1>"
  let htmlStr = "<h1>这是html内容,可以被解析</h1>"
</script>
<style scoped>
</style>

2.4 v-on:事件监听器

  • 给元素绑定事件监听器,简写为"@"
  • 参数:event对象
  • 修饰符:
    • .stop - 阻止冒泡,调用 event.stopPropagation()。
    • .prevent - 阻止默认行为,调用 event.preventDefault()。
    • .capture - 在捕获模式添加事件监听器。
    • .self - 只有事件从元素本身发出才触发处理函数。
    • .{keyAlias} - 只在某些按键下触发处理函数。
    • .once - 最多触发一次处理函数。
    • .left - 只在鼠标左键事件触发处理函数。
    • .right - 只在鼠标右键事件触发处理函数。
    • .middle - 只在鼠标中键事件触发处理函数。
    • .passive - 通过 { passive: true } 附加一个 DOM 事件。
<template>
  <div>
    <button v-on:click="onclick1">普通点击</button>
    <div v-on:click="testPropogation">
      防止冒泡点击,使用@别名绑定
      <button @click.stop="onclick2">防冒泡点击</button>
    </div>
    <div @click.capture="captureHandler">
      captureHandler:捕获触发click,点button,先触发captureHandler,再必testCapture
      <button @click="testCapture">testCapture</button>
    </div>
    <a href="https://www.baidu.com" @click.prevent="preventHandler">点击不跳转</a>
    <button @click.once="onceHandler">只响应一次,再点没用</button>
    <div>
      按下enter触发
      <input @keyup.enter="onEnter" />
    </div>
  </div>
</template>

<script setup>
 function onclick1(){
  alert("普通点击")
 }
//  冒泡测试
 function onclick2(){
  alert("防冒泡点击")
 }
 function testPropogation(){
  alert("点击div或冒泡触发")
 }
//  捕获测试
function captureHandler(){
  alert("点了外层div")
}
function testCapture(){
  alert("捕获触发,或者直接点击按钮触发")
}
// prevent测试
function preventHandler(){
  alert("preventHandler")
}
// .once测试
function onceHandler(){
  alert("once事件触发,再点没用")
}
// .{keyAlias}测试
function onEnter(){
  alert("按下enter键")
}
</script>
<style scoped>
</style>


2.6 动态绑定v-bind

  • 用于绑定 class 或 style
  • 用于绑定组件prop
  • 简写
<template>
  <div>
    <!-- 绑定DOM属性 -->
    <img style="width:100px" v-bind:src="imgSrc"/>
    <!-- 绑定style -->
    <img :style="{width:'200px',height:'100px',marginLeft:'20px'}" v-bind:src="imgSrc"/>
    <!-- 绑定class -->
    <div :class="classArr" >绑定class数组</div>

  </div>
</template>

<script setup>
let imgSrc = "http://imgsrc.baidu.com/baike/pic/item/ac345982b2b7d0a25cd01174cbef76094b369a39.jpg"
// 绑定class
let classArr = ['w100','bg-blue']
</script>

<style >
.w100{
  width: 100px;
  height: 100px;
}
.bg-blue{
  background: blue;
}
</style>

2.7 v-model表单元素值绑定

  • 在表单输入元素或组件上创建双向绑定
  • 支持标签:input,select,textarea或者vue components
  • 修饰符:
    • .lazy - 监听 change 事件而不是 input
    • .number - 将输入的合法字符串转为数字
    • .trim - 移除输入内容两端空格
<template>
  <div>
    输入--------》
    <input type="text" v-model="inputVal">
    双向绑定显示--------》
    <div>
      inputVal: {{inputVal}}
    </div>
  </div>
</template>
<script setup>
// 使用 ref() 函数来声明响应式状态
import {ref,reactive} from "vue"
let inputVal=ref("aaa")
// ref对象通过.value来获取其值
console.log(inputVal.value)
</script>
<style>
  
</style>

三、计算属性与监视

3.1 计算属性computed

  • 对于复杂的变量值(需要进一步通过逻辑处理返回的值)推荐通过计算属性来定义
  • 返回值:一个计算属性 ref,但计算属性 ref 也会在模板中自动解包,因此在模板表达式中引用时无需添加 .value
  • 计算属性会自动追踪响应式依赖
  • computed函数参数:默认为一个getter函数,函数返回值即为想要的计算结果。传入包括get,set函数的对象可设置读写操作
<template>
  <div>计算属性1(默认只可读):{{ authorMsg }}</div>
  <div>计算属性2:{{fullName}}</div>
</template>
<script setup>
// ref() 函数来声明响应式状态
// computed() 函数来声明计算属性
import { ref,computed } from "vue";
let author = {
  name:"张三",
  fruits:["apple","banana","peach","cherry"]
}
// 示例1:默认传入一个getter函数
let authorMsg = computed(()=>{
  let authorName = author.name
  let fruitsStr = author.fruits.map(item=>item+',')
  return `${authorName}喜欢吃的水果有:${fruitsStr}`
})


const firstName = ref('张')
const lastName = ref('三')

const fullName = computed({
  // getter
  get() {
    return firstName.value + ' ' + lastName.value
  },
  // setter
  set(newValue) {
    // 注意:我们这里使用的是解构赋值语法
    let [first, last] = newValue.split("")
    firstName.value=first
    lastName.value =last
    
  }
})
setTimeout(() => {
  fullName.value="王五"
}, 2000);
</script>
<style>
</style>

3.2 watch侦听器

  • 概述:侦听器,在侦听的某个响应式状态发生变化时,触发其回调函数
  • 应用场景:根据异步操作的结果去修改另一处的状态
  • 语法:watch(数据源, 回调函数)
  • 数据源: ref (包括计算属性)、一个响应式对象(reactive)、一个 getter 函数、或多个数据源组成的数组
  • 深层侦听属性:deep: true
  • 立即回调属性:immediate: true
  • 回调触发时间: 默认情况下,回调会在vue组件更新之前调用,因此若在回调中访问DOM会是更新前的状态,所以尽量避免在watch回调中访问dom。如果想在回调中访问Vue更新之后 的DOM,需要添加属性 {flush: ‘post’}
  • 属性语法
watch(source, callback, {
	deep: true, // 深层侦听
	immediate: true, // 立即执行一次回调
  flush: 'post', // 访问Vue更新之后的DOM
})
  • 示例
<template>
  <div>
    <div @click="randomChange('x')">触发x变化</div>
    <div @click="randomChange('y')">触发y变化</div>
    <div @click="() => (obj.count = 10)">reactive值变化</div>
  </div>
</template>
<script setup>
import { ref, watch, reactive } from "vue";
const x = ref(0);
const y = ref(0);

// 触发变化函数
function randomChange(name) {
  let randomNum = Math.random() * 10;
  if (name == "x") {
    x.value = randomNum;
  }
  if (name == "y") {
    y.value = randomNum;
  }
}

// 1、监听单个 ref
watch(x, (newX) => {
  console.log(`例1:监听单个ref,x is ${newX}`);
});

// 2、监听getter 函数,x,y的变化都会触发
watch(
  () => x.value + y.value,
  (sum) => {
    console.log(`例2:getter函数监听变化,sum of x + y is: ${sum}`);
  }
);

// 3、多个来源组成的数组
watch([x, () => y.value], ([newX, newY]) => {
  console.log(`例3:多来源数组监听,x is ${newX} and y is ${newY}`);
});

// 4、监听响应式对象
const obj = reactive({ count: 0 });

// 错误写法,因为 watch() 得到的参数是一个 number
// watch(obj.count, (count) => {
//   console.log(`count is: ${count}`)
// })
// 正确写法
watch(
  () => obj.count,
  (count) => {
    console.log(`例4、监听reactive响应式对象,count is: ${count}`);
  }
);
</script>

<style>
</style>

  • 其他参数

watch(source, (newValue, oldValue) => {
   // 注意:`newValue` 此处和 `oldValue` 是相等的
    // *除非* state.someObject 被整个替换了
    // deep: 深度监听
  // immediate:立即执行,且当 `source` 改变时再次执行
}, { immediate: true ,deep:true})

3.3 watch、watchEffect、computed区别

watchEffect使用场景:有多个依赖项需要侦听,或需要侦听一个嵌套数据结构中的几个属性时,watchEffect() 比深度侦听器更有效

  • 区别:
    • watch 只追踪明确侦听的数据源。它不会追踪任何在回调中访问到的东西.,且仅在数据源确实改变时才会触发回调。watch 会避免在发生副作用时追踪依赖
  • watchEffect,会在副作用发生期间追踪依赖。它会在同步执行过程中,自动追踪所有能访问到的响应式属性。
  • computed,必须有return返回,使用方法与data中的数据一样,如果函数所依赖的属性没有变化,从缓存中读取

四、高级特性

4.1 组件

组件:组件常常被组织成层层嵌套的树状结构。在vue中.vue文件就是组件(单文件组件SFC)

4.1.1 创建组件

1、参考vue-project项目生成目录,其中components就是约定的组件存放目录,在components中新建Child.vue组件如下

  • child.vue
<template>
  <div >
    <h1>{{ msg }}</h1>
  </div>
</template>
<script setup >
import {ref, reactive} from "vue"
let msg = ref("这是Child")
</script>

<style scoped>
</style>

2、父组件中引入。(以App.vue为例,此处以setup语法糖方式编写,只需引入Child.vue就会自动注册该组件。若在optionsApi中需要显示注册components)

  • App.vue
<template>
  <div class="">
    这是Parent
    <p>------------------------分隔线------------------</p>
    <Child />
  </div>
</template>
<script setup lang="ts">
// 引入组件
import Child from './components/Child.vue'
import {ref, reactive} from "vue"

</script>

4.1.2 组件通信

  • 组件通信主要分为:父子组件间通信,非父子组件间通信
  • 父传子:props属性
  • 子传父:子组件自定义事件,并通过$emit触发

1、父传子props

  • Child.vue
<template>
  <div >
    <h1>{{ parentMsg }}</h1>
  </div>
</template>
<script setup >
// 1. 引入defineProps宏
import { defineProps} from "vue"
// 2.定义props
defineProps({
	parentMsg: {type: String}
})
</script>

  • App.vue
<template>
  <div class="">
    这是Parent
    <p>------------------------分隔线------------------</p>
    <!-- 3.传入props -->
    <Child :parentMsg="toChild"/>
  </div>
</template>
<script setup lang="ts">
import Child from './components/Child.vue'
import {ref} from "vue"

let toChild = ref("来自Parent的消息")
</script>

  • 子组件向父组件传递参数——自定义事件,$emit调

2、子传父

  • App.vue
<template>
  <div class="">
    这是Parent
    <p>------------------------分隔线------------------</p>
    <!-- 3.绑定子组件自定义事件 -->
    <Child @sayHi="hiHandler"/>
  </div>
</template>
<script setup lang="ts">
import Child from './components/Child.vue'

// 4.接收子组件抛出事件的参数msg
function hiHandler(msg){
  alert(msg)
}
</script>

  • child.vue
<template>
  <div >
    <h1 @click="clickHandler">点击传给Parent</h1>
  </div>
</template>
<script setup >
// 1. 引入defineEmits宏
import { defineEmits } from "vue"
// 2.定义组件会抛出的事件
const emit  = defineEmits(['sayHi'])

function clickHandler(){
  console.log("child 中触发点击")
  // 3.触发抛出事件
  emit('sayHi','来自Child的消息')
}
</script>

3、py: provice/inject

如果是祖辈组件与孙辈组件间传值,可使用provide、inject

  • provide(key,value), 必须在组件的setup()阶段同步调用
  • inject(key,defaultValue) : 注入一个由祖先组件或整个应用(通过app.provide())提供的值,defaultValue可选,当没匹配到key对应的值时显示
  • 示例:组件结构如下App>Middle>Child
  • App.vue
<template>
  <div class="">
    这是App.vue,子组件为Middle,孙组件为Child(由middle包含)
    <p>------------------------分隔线------------------</p>
    <Middle />
  </div>
</template>
<script setup lang="ts">
import Middle from './components/Middle.vue'
import {provide,ref} from 'vue'

let count = ref(0)

// 提供静态值
provide("appName",'测试Demo')
// 提供响应值
provide("count",count)
</script>
  • Middle.vue
<template>
  <div >
    这是隔代组件,内部引入Child组件
    <Child />
  </div>
</template>
<script setup >
import Child from './Child.vue'
</script>

  • Child.vue
<template>
  <div >
    这是Child.vue内容
    <p>来自app.vue的appName: {{ appName }}</p>
    <p>这是app.vue的count: {{ count }}</p>
  </div>
</template>
<script setup >
import {inject} from 'vue'

let appName = inject("appName")
let count = inject("count")

</script>

4.2 生命周期

在vue3 compositionAPI中,生命周期钩子函数都有on前缀,常用如onMounted,onUpdated,onUnmounted(),onActived()

  • onMounted(): 组件挂载完成后执行
  • onUpdated(), 在组件因为响应式状态变更而更新其 DOM 树之后调用
  • onUnMounted(), 在组件实例被卸载之后调用。
  • onActived(),若组件实例是 缓存树的一部分,当组件被插入到 DOM 中时调用。
<template>
  <div >
    {{ count }}
  </div>
</template>
<script setup lang="ts">

import {ref, onMounted,onUpdated} from "vue"
let count = ref(0)
setTimeout(()=>{
  count.value++
  console.log("count改变将触发onUpdated")
},2000)

onMounted(()=>{
  console.log("onMounted")
})
onUpdated(()=>{
  console.log("onUpdated")
})
</script>

六、脚手架案例

6.1 vue-router:前端路由

官网地址:https://router.vuejs.org/zh/, 在创建单页应用项目时脚手架会提醒是否安装vue router,VueRouter作为前端路由库,控制整个Vue项目的页面跳转服务。以下示例介绍vue-router集成到vue项目中的使用
1、安装vue router

npm install vue-router@4

2、定义路由
- 项目目录中新建router文件夹,并新建index.js

// router/index.js
import {createRouter,createWebHashHistory} from 'vue-router'

// 1、定义路由组件(实际应用中通过导入.vue文件组件)
const Home = ()=>import("@/pages/Home.vue")
const About = ()=>import("@/pages/About.vue")

// 2、定义路由
const routes = [
  { path: '/', component: Home },
  { path: '/about', component: About },
]

// 3. 创建路由实例并传递 `routes` 配置
const router = createRouter({
  history:createWebHashHistory(), // 以hash模式创建路由
  routes,
})

export default router

3、挂载路由到Vue实例中
- 打开项目src/main.js文件

// main.js
import './assets/main.css'
import router from '@/router'

import { createApp } from 'vue'
import App from './App.vue'

// 创建应用实例
const app = createApp(App)
// 整个应用支持路由
app.use(router)
// 挂载整个应用
app.mount('#app')

4、页面中通过router-view渲染

  • App.vue

<template>
  <div>
    这是App.vu
    <p>------------------------分隔线------------------</p>
    <router-link to="/">Go to Home</router-link> <br>
    <router-link to="/about">Go to About</router-link>
   <div class="router-page" style="border:1px solid #ddd;padding:10px;">
    <router-view></router-view>
    </div>
  </div>
</template>
<script setup >
</script>

5、路由跳转及传参

在vue3中使用组合式API编写router业务时,参考文档:https://router.vuejs.org/zh/guide/advanced/composition-api.html

<script setup >
import {useRouter, useRoute } from 'vue-router'
import {onMounted} from 'vue'
const router = useRouter()
const route = useRoute()

function goAbout(){
  // 路由跳转
  router.push({path:'/about',query:{name:'lala'}})
}
onMounted(()=>{
  console.log(route.path)
})
console.log(router)
</script>

6.2 axios:接口请求

官网地址: https://www.npmjs.com/package/axios#axios-api

axios是一个基于Promise的http客户端请求工具,可以在浏览器或者node.js中使用。
1、安装

npm install axios --save

2、src目录下创建api文件夹,简单封装
- 一般对axios进行简单封装,使用统一域名,请求拦截,响应拦截,设置超时时间等

// src/api/http.js
import axios from 'axios'

const request = axios.create({
  baseURL: 'https://www.xxx.com', // 后端服务地址
  timeout: 120000,  // 超时时间
})

// 请求拦截器,用于在发出请求前,做一些操作
request.interceptors.request.use(config=>{
  // 假设本地有token
  if(localStorage.getItem("token")){
    config.headers.token = token
  }
  return config
})

// 响应拦截器,用于处理后端报错等
request.interceptors.response.use(response=>{
  if(response.status!==200){
    console.log("请求响应服务出错了,具体再看")
  }
  return response
})

export default request

  • 封装业务请求
// src/api/login.js
import request from './http'

const Api = {
  getCode:'/api/v1/getCode',
  login:'/api/v1/login'
}

// 假设获取验证码
export function getCode(params){
  return request.get(Api.getCode, params)
}

// 登录
export function login(params){
  return request.post(Api.login, params)
}

3、组件间使用(伪代码示例用)
- pages/login.vue

<template>
  <div >
    这是登录页
  </div>
</template>
<script setup >
import {getCode,login} from "@/api/login"
import {ref, onMounted} from "vue"

// 调用请求
let params = {
  name:'zhangsan',
  password:'123455'
}
login(params).then(res=>{
  console.log(res)
})
</script>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

摆脱焦虑,释放技术人的潜能!

引言 在这个瞬息万变的时代&#xff0c;每个人都或多或少会面临职场生涯中的焦虑与迷茫。这种焦虑具有时代性特质&#xff0c;既源于对自我的疑惑&#xff0c;也对这个变化太快的世界感到不安。 对于技术从业者来说&#xff0c;科技变革加速带来的冲击尤为强烈。面对日新月异的…

【Visual Studio Code】--- Win11 C盘爆满 修改 Code 插件数据和缓存的保存路径

Win11 C盘爆满 修改 Code 插件数据和缓存的保存路径 一、概述二、修改 Code 插件数据和缓存的保存路径 一、概述 一个好的文章能够帮助开发者完成更便捷、更快速的开发。书山有路勤为径&#xff0c;学海无涯苦作舟。我是秋知叶i、期望每一个阅读了我的文章的开发者都能够有所成…

天津和则百顺国际贸易有限公司:连接中国和印度汽车品牌的国际间贸易桥梁

全球汽车产业正迎来前所未有的变革,而中国和印度作为两大新兴市场,其汽车品牌也在逐步崭露头角。在这个背景下,天津和则百顺国际贸易有限公司(以下简称和则百顺)以其出色的贸易服务,成为了连接中国和印度汽车品牌的重要国际间贸易桥梁。 中国和印度汽车市场的崛起 中国和印度分…

STM32CubeMx驱动SG90(360度)

SG90 360度是一直转 而不是给定角度转的 pwm周期必须为20ms 0.5ms占空比 反转速度最大 1.5ms 不转 2.5ms正转速度最大

如何实现安全上网

l 场景描述 政府、军工、科研等涉密单位或企业往往要比其他组织更早接触高精尖的技术与产品&#xff0c;相对应的数据保密性要求更高。常规的内外网物理隔离手段&#xff0c;已经满足不了这些涉密单位的保密需求&#xff0c;发展到现在&#xff0c;需求已经演变成既要保证网络…

学习笔记十四:K8S最小调度单元POD概述

K8S最小调度单元POD概述 k8s核心资源Pod介绍Pod是什么Pod如何管理多个容器Pod网络Pod存储代码自动发版更新收集业务日志 Pod工作方式自主式Pod控制器管理的Pod(防误删除) 如何基于Pod运行应用 k8s核心资源Pod介绍 K8s官方文档&#xff1a;https://kubernetes.io/ K8s中文官方文…

STM32--TIM定时器(3)

文章目录 输入捕获简介频率测量输入捕获通道输入捕获基本结构PWMI的基本结构输入捕获模式测量PWM频率和占空比代码 编码器接口正交编码器工作模式接口基本结构TIM编码接口器测速代码&#xff1a; 输入捕获简介 输入捕获IC(Input Capture)&#xff0c;是处理器捕获外部输入信号…

DDPM: Denoising Diffusion Probabilistic Models

DDPM: Denoising Diffusion Probabilistic Models 去噪扩散模型前向过程-加噪声反向过程-去噪声 去噪扩散模型 论文题目&#xff1a;Denoising Diffusion Probabilistic Models (DDPM) 论文来源&#xff1a;NIPS, 2020 论文地址&#xff1a;https://arxiv.org/abs/2006.11239 论…

ubuntu18.04安装cuda

卸载之前安装的驱动 sudo apt-get purge nvidia*安装驱动 方法1&#xff1a; 查看显卡适配的NVIDIA的驱动 ubuntu-drivers devices安装recommend推荐的版本 sudo apt-get install nvidia-driver-455方法2&#xff1a; 或者直接使用下面命令安装 sudo ubuntu-drivers au…

Python程序设计——函数

学习目标 定义带形参的函数。用实参来调用函数。区分带返回值和不带返回值的函数。使用位置参数和关键字参数调用函数。通过传参数的引用值来传递参数。开发可重用代码来模块化程序&#xff0c;使程序易读、易调试和易维护。为可重用函数创建模块。决定变量的作用域。定义带默认…

纷享销客位列“2023企业客户关系管理(CRM)服务TOP10”第一名

近日&#xff0c;《互联网周刊》&eNet研究院发布“2023企业客户关系管理(CRM)服务TOP10”榜单&#xff0c;纷享销客连接型CRM凭借出色的产品实力和服务实践&#xff0c;位居 CRM企业排名首位。 2023年&#xff0c;穿越周期&#xff0c;用数字化的力量重塑企业经营与增长的逻…

cesium加载天地图

成果图 源码 const tiandituTk 你的tokenvar viewer new Cesium.Viewer("cesiumContainer", {imageryProvider: new Cesium.WebMapTileServiceImageryProvider({url: "http://t0.tianditu.com/img_w/wmts?servicewmts&requestGetTile&version1.0.0&a…

Win10设置代理操作步骤

1、依次点击打开控制面板--》网络和internet-》internet选项 2、选择“连接”--》点击打开局域网设置 3、勾选“为LAN使用代理服务器”&#xff0c;并根据自己需要设置地址和端口&#xff0c;点击【确定】按钮保存即可 4、使用完后千万记得关闭代理&#xff08;即取消勾选上一步…

alertmanager创建nginx-ingress basic auth鉴权

步骤 生成密码 printf "admin:$(openssl passwd -crypt xxxxxx)\n" >> auth 创建新的 Kubernetes 密钥 kubectl create secret generic basic-auth --from-file auth -n victoria-metrics 修改 ingress 以使用 secret 中的凭证来实现基本身份验证 编辑 P…

RabbitMQ和JMeter,一个完美的组合!优化你的中间件处理方式

RabbitMQ是实现了高级消息队列协议&#xff08;AMQP&#xff09;的开源消息中间件&#xff0c;它是基于Erlang语言编写的&#xff0c;并发能力强&#xff0c;性能好&#xff0c;是目前主流的消息队列中间件之一。 RabbitMQ的安装可参照官网&#xff08; https://www.rabbitmq.c…

每日汇评:黄金在 200 日移动平均线附近似乎很脆弱,关注美国零售销售

1、金价预计将巩固其近期跌势&#xff0c;至 6 月初以来的最低水平&#xff1b; 2、对美联储再次加息的押注继续限制了贵金属的上涨&#xff1b; 3、金融市场现在期待美国零售销售报告带来一些有意义的推动&#xff1b; 周二金价难以获得任何有意义的牵引力&#xff0c;并在…

JAVA毕业设计094—基于Java+Springboot+Vue的人事管理系统(源码+数据库+8000字论文)

基于JavaSpringbootVue的人事管理系统(源码数据库8000字论文)094 一、系统介绍 本系统前后端分离 本系统分为管理员、HR、员工三种角色 用户角色包含以下功能&#xff1a; 登录、个人培训、个人奖惩、个人调动、员工打卡、个人中心、密码修改、在线聊天 HR角色包含以下功…

【C++】开源:跨平台Excel处理库-libxlsxwriter配置使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍Excel处理库-libxlsxwriter配置使用。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&…

达梦数据库dbms_stats包的操作实践记录

索引的统计信息收集 GATHER_INDEX_STATSindex_stats_show 根据模式名&#xff0c;索引名获得该索引的统计信息。用于经过 GATHER_TABLE_STATS、GATHER_INDEX_STATS 或 GATHER_SCHEMA_STATS 收集之后展示。返回两个结果集&#xff1a;一个是索引的统计信息&#xff1b;另一个是…

23款奔驰S400商务型升级原厂HUD抬头显示系统,增加您的行车安全

HUD是平视显示器的简称&#xff0c;它原先是运用在航空器上的飞行辅助仪器。指飞行员不需要低头&#xff0c;就能够看到他需要的重要资讯。由于HUD的方便性以及能够提高飞行安全&#xff0c;这项技术后来也发展到汽车行业。汽车搭载的HUD抬头数字显示功能&#xff0c;是利用光学…