Vue框架学习

一、Vue3

基础

创建vue3工程

  1. 安装Node.js
  2. 在你所要存放目录位置 cmd 终端运行 npm create vue@latest
  3. 输入工程名字
  4. 需要ts JSX 选No 是否配置路由 NO(初步学习) 是否配置管理 No 是否配置测试 No Testing Solution NO 是否选择ESLint语法检查先不选 选NO
  5. 用 VSCode打开所在工程文件夹
  6. npm i 安装所有配置依赖

index.html 入口文件 启动前端工程 找到package.json "script"中的dev npm run dev

在src下面的main.ts文件中

import './assets/main.css'
// 引入createApp用于创建应用
import { createApp } from 'vue'
// 引入App根组件
import App from './App.vue'createApp(App).mount('#app')

App.vue 模板规范化 三部分分别写什么

<template><!-- html --><div class="app2"><h1>你好啊!</h1></div>
</template><script lang="ts">
// JS或TS
export default {name: "App" // 组件名
};
</script><style>
.app2 {background-color: #ddd;/* 盒子阴影 */box-shadow: 0 0 10px;border-radius: 10px;padding: 20px;
}
</style>

Vue模板语法

插值语法
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>模板语法</title><script src="../js/vue.js"></script>
</head><body><!-- 准备好一个容器 --><div id="root"><h1>插值语法</h1><h3>你好,{{name}}</h3><hr /></div>
</body><script type="text/javascript">Vue.config.productionTip = false;    // 阻止 vue 在启动时生成生产提示。const vm = new Vue({el: '#root',data: {name: 'Jack'}})
</script></html>
指令语法
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>模板语法</title><script src="../js/vue.js"></script>
</head>
<!-- Vue模板语法有2大类:1. 插值语法:{{}},用于解析标签体内容写法:  {{xxx}},  xxx是js表达式,且可以直接读取到data中的所有属性。2. 指令语法:功能:用于解析标签(包括:标签属性、标签体内容、绑定事件...)v-xxxx,用于解析标签、标签属性、以及特殊属性--><body><!-- 准备好一个容器 --><div id="root"><h1>插值语法</h1><h3>你好,{{name}}</h3><hr /><h1>指令语法</h1><a v-bind:href="school.url">点我去{{school.name}}查找资料1</a><br /><a :href="school.url">点我去{{school.name}}查找资料2</a> <!-- v-bind     ==> 可以简写为 : --></div>
</body><script type="text/javascript">Vue.config.productionTip = false;    // 阻止 vue 在启动时生成生产提示。const vm = new Vue({el: '#root',data: {name: 'Jack',school: {  // 层级标签name: "百度",url: "http://www.baidu.com"}}})
</script></html><!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>模板语法</title><script src="../js/vue.js"></script>
</head>
<!-- Vue模板语法有2大类:1. 插值语法:{{}},用于解析标签体内容写法:  {{xxx}},  xxx是js表达式,且可以直接读取到data中的所有属性。2. 指令语法:功能:用于解析标签(包括:标签属性、标签体内容、绑定事件...)v-xxxx,用于解析标签、标签属性、以及特殊属性--><body><!-- 准备好一个容器 --><div id="root"><h1>插值语法</h1><h3>你好,{{name}}</h3><hr /><h1>指令语法</h1><a v-bind:href="school.url">点我去{{school.name}}查找资料1</a><br /><a :href="school.url">点我去{{school.name}}查找资料2</a> <!-- v-bind     ==> 可以简写为 : --></div>
</body><script type="text/javascript">Vue.config.productionTip = false;    // 阻止 vue 在启动时生成生产提示。const vm = new Vue({el: '#root',data: {name: 'Jack',school: {  // 层级标签name: "百度",url: "http://www.baidu.com"}}})
</script></html>

数据绑定

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>数据绑定</title><!-- <script src="../js/vue.js"></script> --><script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head><!-- Vue中有2种数据绑定的方式:1.单向绑定(v-bind):数据只能从data流向页面2.双向绑定(v-model):数据不仅能从data流向页面,还可以从页面流向data备注:1.双向绑定一般都应用在表单类元素上(如:input、select等)2.v-model:value 可以简写为 v-model ,因为v-model默认收集的就是value值3.v-bind:value 可以简写为 :value --><body><div id="app"><!-- 普通写法 --><!-- 单向数据绑定:<input type="text" v-bind:value="name"> <br />双向数据绑定:<input type="text" v-model:value="name1"> --><!-- 简写 -->单向数据绑定:<input type="text" :value="name"><br />双向数据绑定:<input type="text" v-model:value="name1"></div><script>const { createApp, ref } = VuecreateApp({setup() {const name = ref('Hello vue!')const name1 = ref('Hello vue!')return {name, name1}}}).mount('#app')</script>
</body></html>
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>数据绑定 Vue2</title><!-- <script src="../js/vue.js"></script> --><script src="../js/vue.js"></script>
</head><!-- Vue中有2种数据绑定的方式:1.单向绑定(v-bind):数据只能从data流向页面2.双向绑定(v-model):数据不仅能从data流向页面,还可以从页面流向data备注:1.双向绑定一般都应用在表单类元素上(如:input、select等)2.v-model:value 可以简写为 v-model ,因为v-model默认收集的就是value值3.v-bind:value 可以简写为 :value --><body><div id="root"><!-- 普通写法 --><!-- 单向数据绑定:<input type="text" v-bind:value="name"> <br />双向数据绑定:<input type="text" v-model:value="name1"> --><!-- 简写 -->单向数据绑定:<input type="text" :value="name"><br />双向数据绑定:<input type="text" v-model:value="name">  <br/><!--如下代码是错误的,因为v-model只能应用在表单类元素(输入类元素)上 --><h2 v-model:x="name">你好呀</h2></div><script>new Vue({el:'#root',data:{name:'百度'}})</script>
</body></html>

el与data的两种写法

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>el与data的两种写法</title><script src="../js/vue.js"></script>
</head><body><!-- data与el的2种写法1.el有2种写法(1).new Vue时候配置el属性。(2).先创建Vue实例,随后再通过vm.$mount('#root')指定el的值2.data有2种写法(1).对象式(2).函数式如何选择:目前那种写法都可以,以后学习到组件时,data必须使用函数式,否则会报错3.一个重要的原则:由Vue管理的函数,一定不要写箭头函数,一旦写了箭头函数,this就不再是Vue实例了
--><div id="root"><h1>你好,{{name}}</h1></div>
</body><script type="text/javascript">// Vue.config.productionTip = false;// el的两种写法/* const v = new Vue({//     // el: '#root',    // 第一种写法//     data: {//         name: '白羽'//     }// })// v.$mount('#root')  // 第二种写法 */// data的两种写法new Vue({el: '#root',// data的第一种写法:对象式/*data: {name: '白羽'}*/// data的第二种写法:函数式data: function () {return {name: '杨洋'}}})</script></html>

MVVM模型

在这里插入图片描述

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>理解MVVM</title><script src="../js/vue.js"></script>
</head><!-- MVVM模型:1. M:模型(Model):data中的数据2. V:视图(View):模板代码3. VM:视图模型(ViewModel):Vue实例观察发现:1. data中所有的属性,最后都出现在了vm身上2. vm代理了data中的所有属性   vm身上所有的属性  及  Vue原型上所有属性,在Vue模板中都可以直接使用。
--><body><!-- 准备好一个容器 --><div id="root"><!-- View模型 --><h1>学校名称:{{name}}</h1><h1>学校地址:{{address}}</h1></div>
</body><script>// ViewModel 模型   vue实例const vue = new Vue({el: '#root',data: {// Model 数据name: '尚硅谷',address: '北京'}})</script></html>

Object.defineProperty

<script>let person = {name:'张三',sex:'男',}
// 直接在person后面直接添加元素  age:18Object.defineProperty(person,'age',{value:18})
console.log(person)</script>
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>1.回顾Object.defineproperty</title>
</head><body><script>let number = 18let person = {name: '张三',sex: '男',// age: 18}Object.defineProperty(person, 'age', {// value: 18,		使用这种方式去遍历// enumerable: true,  // 控制属性是否可以枚举,默认值是false// writable: true,  // 控制属性是否可以修改,默认值是false// configurable: true  // 控制属性是否可以删除,默认值是false// 当有人读取person的age属性时,get函数(getter)就会被调用,且返回值就是age的值// 配置修改,通过定义的number来进行person中age的修改get: function () {return number},// 当有人修改person的age属性时,set函数(setter)就会被调用,且会收到修改的具体值set: function (value) {console.log('有人修改了age属性,且值是', value)number = value}})// console.log(Object.keys(person))// for (let key in person) {//     console.log(person[key])// }console.log(person);</script>
</body></html>

数据代理

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>何为数据代理</title><script src="../js/vue.js"></script>
</head><body><!-- 数据代理:通过一个对象代理对另一个对象中属性的操作(读/写) --><script>let obj = { x: 100 }let obj2 = { y: 200 }// 想修改obj2.x的值,实际上修改obj.x的值Object.defineProperty(obj2, 'x', {get() {return obj.x},set(value) {obj.x = value}})</script>
</body></html>

在这里插入图片描述

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Vue中的数据代理</title><script src="../js/vue.js"></script>
</head>
<!-- 1.Vue中的数据代理:通过vm对象来代理data对象中的属性的操作(读/写)2.Vue中数据代理的好处:更加方便的操作data中的数据3.基本原理:通过Object.defineProperty()把data中的属性添加到vm上。为每一个添加到vm上添加一个属性,都指定一个getter/setter。为getter/setter内部去操作(读/写)data中的属性。--><body><div id="root"><h2>学校名称:{{name}}</h2><h2>学校地址:{{address}}</h2></div>// vm._data = data  两者是一样的 vm._data = options.data = data<script>// 最初语法//const vm = new Vue({//el: '#root',//data: {//name: '尚硅谷',//address: '北京'//}//})let data = {name:'百度',address:'北京'}const vm = new Vue({el:'#root',data})</script>
</body></html>

事件处理

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>事件处理</title><script src="../js/vue.js"></script>
</head><body><div id="root"><h2>欢迎来到{{name}}学习</h2><!-- <button v-on:click="showInfo">点我提示信息</button> --><!-- 简写形式 --><button @click="showInfo1">点我提示信息1(不传参)</button><button @click="showInfo2($event,66)">点我提示信息2(传参)</button></div>
</body><script>new Vue({el: '#root',data: {name: '尚硅谷'},methods: {showInfo1(event) {alert('同学你好!')},showInfo2(event, number) {alert('同学你好!!')console.log(event, number)}}})</script></html>
事件修饰符
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>事件修饰符</title><script src="../js/vue.js"></script><style>* {margin-top: 20px;/* 设置间距 */}.demo1 {width: 200px;height: 200px;background-color: skyblue;}.box1 {padding: 5px;background-color: pink;}.box2 {padding: 5px;background-color: greenyellow;}.list {width: 200px;height: 200px;background-color: peru;overflow: auto;}li {height: 100px;}</style>
</head><!-- Vue中的事件修饰符:1.prevent:阻止默认行为(常用)2.stop:阻止事件冒泡(常用)3.once:事件只触发一次(常用)4.capture:使用事件捕获模式5.self:只有事件源才触发    只有event.target是当前操作的元素是才触发事件6.passive:事件处理函数的默认行为不会被立即执行,而是被放入一个队列中,在队列中的函数执行完之后再执行默认事件--><body><div id="root"><h2>欢迎来到{{name}}学习</h2><!-- 网页会默认跳转      阻止默认行为@click(常用) --><a href="http://www.atguigu.com" @click.prevent="showInfo">点我提示信息1</a><!-- 阻止事件冒泡(常用) --><div class="demo1" @click="showInfo"><button @click.stop="showInfo">点我提示信息2</button></div><!-- 事件只触发一次(常用) --><button @click.once="showInfo">点我提示信息3</button><!-- 使用事件的捕获模式 --><div class="box1" @click.capture="showMsg(1)">div1<div class="box2" @click="showMsg(2)">div2</div></div><!-- 只有event.target是当前操作的元素是才触发事件 --><div class="demo1" @click.self="showInfo"><button @click="showInfo">点我提示信息4</button></div><!-- 事件的默认行为立即执行,无需等待事件回调执行完毕 --><ul @wheel.passive="demo" class="list"><li>1</li><li>2</li><li>3</li><li>4</li></ul></div>
</body><script type="text/javascript">Vue.config.productionTip = false    // 阻止在控制台输出生产模式的提示// 创建Vue实例对象new Vue({el: '#root',data: {name: '尚硅谷'},methods: {showInfo(e) {// e.preventDefault()  // 阻止默认行为// e.stopPropagation()    // 阻止事件冒泡// alert('同学你好')console.log(e.target)},showMsg(msg) {console.log(msg)},demo() {// console.log('@')for (let i = 0; i < 10000; i++) {console.log('#')}console.log('累坏了')}}})
</script></html>
键盘事件
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>键盘事件</title><script src="../js/vue.js"></script>
</head><!-- 1.Vue中常用的按键别名:回车 => enter删除 => delete (捕获"删除"和"退格"键)退出 => esc空格 => space换行 => tab上 => up下 => down左 => left右 => right2.Vue未提供别名的按键,可以使用按键原始的key值去绑定,但注意要转为kebab-case(短横线命名)3.系统修饰键(用法特殊):ctrl、alt、shift、meta(1).配合keyup使用:按下修饰键的同时,再按下其他键,事件才被触发。(2).配合keydown使用:只要按下修饰键,事件被触发。4.也可以使用keyCode去指定具体的按键(不推荐)5.Vue.config.keyCodes.自定义键名 = 键码,可以去定制按键的别名--><body><div id="root"><h2>欢迎来到{{name}}学习</h2><!-- @keyup.enter表示按下回车触发showInfo方法 --><input type="text" placeholder="按下回车提示输入" @keyup.enter="showInfo"></input></div>
</body>
<script>new Vue({el: '#root',data: {name: '尚硅谷'},methods: {showInfo(event) {//if (event.keyCode === 13) {console.log(event.target.value)//}}}})
</script></html>

计算属性

插值语法
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>姓名案例_插值语法实现</title><script src="../js/vue.js"></script>
</head><body><div id="root">姓:<input type="text" v-model:value="firstName"> <br /><br />名:<input type="text" v-model:value="lastName"> <br /><br />姓名:<span>{{firstName}}-{{lastName}}</span></div>
</body><script>new Vue({el: '#root',data: {firstName: '张',lastName: '三'}})
</script></html>
methods实现
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>姓名案例_插值语法实现</title><script src="../js/vue.js"></script>
</head><body><div id="root">姓:<input type="text" v-model:value="firstName"> <br /><br />名:<input type="text" v-model:value="lastName"> <br /><br />姓名:<span>{{firstName}}-{{lastName}}</span></div>
</body><script>new Vue({el: '#root',data: {firstName: '张',lastName: '三'}})
</script></html>
计算属性实现
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>计算属性实现</title><script src="../js/vue.js"></script>
</head><body><div id="root">姓:<input type="text" v-model="firstName"> <br /><br />名:<input type="text" v-model:value="lastName"> <br /><br />全名:<span>{{fullName}}</span></div>
</body><!-- 
计算属性:1.定义:要用的属性不存在,要通过已有属性计算得来2.原理:底层借助了Object.defineProperty方法提供的getter和setter3.get函数什么时候执行?1.初次读取时会执行一次2.当依赖的数据发生变化时会再次被调用4.优势:与methods相比,内部有缓存机制,效率更高,调试方便。5.备注:1.计算属性最终会出现在vm上,直接读取使用即可2.使用计算属性要被修改,那必须写set函数去响应修改,且set中要引起计算时候依赖的数据发生改变
--><script>const vm = new Vue({el: '#root',data: {firstName: '张',lastName: '三'},computed: {fullName: {// get有什么作用? 当有人·读取fullName时,get就会执行,且返回值就作为fullName的值// get什么时候调用? 1.初次读取fullName时。  2.所依赖的数据发生变化时get() {  // 读取console.log('get被调用了')// console.log(this)   // 此处的this是vmreturn this.firstName + '-' + this.lastName},// get什么时候调用? 当fullName被修改时set(value) {   // 修改console.log('set', value)// console.log(value)  // value就是fullName的最新值const arr = value.split('-')this.firstName = arr[0]this.lastName = arr[1]}}}})
</script></html>

监视属性

e({
el: ‘#root’,
data: {
firstName: ‘张’,
lastName: ‘三’
},
computed: {
fullName: {
// get有什么作用? 当有人·读取fullName时,get就会执行,且返回值就作为fullName的值
// get什么时候调用? 1.初次读取fullName时。 2.所依赖的数据发生变化时
get() { // 读取
console.log(‘get被调用了’)
// console.log(this) // 此处的this是vm
return this.firstName + ‘-’ + this.lastName
},
// get什么时候调用? 当fullName被修改时
set(value) { // 修改
console.log(‘set’, value)
// console.log(value) // value就是fullName的最新值
const arr = value.split(‘-’)
this.firstName = arr[0]
this.lastName = arr[1]
}
}
}
})

~~~

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

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

相关文章

部署若依微服务遇到的坑

一、用Windows部署nacos 1、启动失败&#xff0c;因为nacos默认开启为器群模式。单体需要加上图下代码 2、nacos配置内置MySQL时需要执行config文件夹下的SQL文件 3、springboot启动报错 java.nio.charset.MalformedInputException: Input length 1或Input length 2-CSDN博…

RabbitMQ系列(三)基本概念之Consumer

在 RabbitMQ 中&#xff0c;Consumer&#xff08;消费者&#xff09; 是负责从队列&#xff08;Queue&#xff09;中获取并处理消息的客户端角色&#xff0c;其核心机制与功能如下&#xff1a; 一、Consumer 的定义与核心作用 消息处理终端 Consumer 通过订阅或拉取队列中的消…

Trae根据原型设计稿生成微信小程序密码输入框的踩坑记录

一、需求描述 最近经常使用Trae生成一些小组件和功能代码&#xff08;对Trae赶兴趣的可以看之前的文章《TraeAi上手体验》&#xff09;&#xff0c;刚好在用uniapp开发微信小程序时需要开发一个输入密码的弹框组件&#xff0c;于是想用Trae来实现。原型设计稿如下&#xff1a;…

SuperMap iClient3D for WebGL 影像数据可视范围控制

在共享同一影像底图的服务场景中&#xff0c;如何基于用户权限体系实现差异化的数据可视范围控制&#xff1f;SuperMap iClient3D for WebGL提供了自定义区域影像裁剪的方法。让我们一起看看吧&#xff01; 一、数据制作 对于上述视频中的地图制作&#xff0c;此处不做讲述&am…

STM32中使用PWM对舵机控制

目录 1、硬件JIE 2、PWM口配置 3、角度转换 4、main函数中应用 5、工程下载连接 1、硬件介绍 单片机&#xff1a;STM32F1 舵机&#xff1a;MG995 2、PWM口配置 20毫秒的PWM脉冲占空比&#xff0c;对舵机控制效果较好 计算的公式&#xff1a; PSC、ARR值的选取&#xf…

5、使用 pgAdmin4 图形化创建和管理 PostgreSQL 数据库

通过上几篇文章我们讲解了如何安装 PostgreSQL 数据库软件和 pgAdmin4 图形化管理工具。 今天我们继续学习如何通过 pgAdmin4 管理工具图形化创建和管理 PostgreSQL 数据库。 一、PostgreSQL的基本工作方式 在学习如何使用PostgreSQL创建数据库之前&#xff0c;我们需要了解一…

Protobuf原理与序列化

本文目录 1. Protobuf介绍2. Protobuf的优势3. 编写Protobuf头部全局定义消息结构具体定义字段类型定义标签号Base128编码 4. TLVProtobuf的TLV编码如何通过Varint表示300&#xff1f; 5. 编译Protobuf6. 构造消息对象 前言&#xff1a;之前写项目的时候只是简单用了下Protobuf…

DeepSeek:面向效率与垂直领域的下一代大语言模型技术解析

本文将深入剖析DeepSeek模型的核心算法架构&#xff0c;揭示其在神经网络技术上的突破性创新&#xff0c;并与主流大模型进行全方位技术对比。文章涵盖模型设计理念、训练范式优化、应用场景差异等关键维度&#xff0c;为读者呈现大语言模型领域的最新发展图景。 一、DeepSeek…

数据安全_笔记系列09_人工智能(AI)与机器学习(ML)在数据安全中的深度应用

数据安全_笔记系列09_人工智能&#xff08;AI&#xff09;与机器学习&#xff08;ML&#xff09;在数据安全中的深度应用 人工智能与机器学习技术通过自动化、智能化的数据分析&#xff0c;显著提升了数据分类、威胁检测的精度与效率&#xff0c;尤其在处理非结构化数据、复杂…

【Python 语法】Python 数据结构

线性结构&#xff08;Linear Structures&#xff09;1. 顺序存储列表&#xff08;List&#xff09;元组&#xff08;Tuple&#xff09;字符串&#xff08;String&#xff09; 2. 线性存储栈&#xff08;Stack&#xff09;队列&#xff08;Queue&#xff09;双端队列&#xff08…

docker本地镜像源搭建

最近Deepseek大火后&#xff0c;接到任务就是帮客户装Dify&#xff0c;每次都头大&#xff0c;因为docker源不能用&#xff0c;实在没办法&#xff0c;只好自己搭要给本地源。话不多说具体如下&#xff1a; 1、更改docker的配置文件&#xff0c;添加自己的私库地址&#xff0c…

Ae 效果详解:粒子运动场

Ae菜单&#xff1a;效果/模拟/粒子运动场 Simulation/Particle Playground 粒子运动场 Particle Playground效果可以用于创建和控制粒子系统&#xff0c;模拟各种自然现象&#xff0c;如烟雾、火焰、雨水或雪等。通过调整粒子的发射点、速度、方向和其他属性&#xff0c;可以精…

CSS 对齐:深入理解与技巧实践

CSS 对齐:深入理解与技巧实践 引言 在网页设计中,元素的对齐是至关重要的。一个页面中元素的对齐方式直接影响到页面的美观度和用户体验。CSS 提供了丰富的对齐属性,使得开发者可以轻松实现各种对齐效果。本文将深入探讨 CSS 对齐的原理、方法和技巧,帮助开发者更好地掌握…

汽车无钥匙进入一键启动操作正确步骤

汽车智能无钥匙进入和一键启动的技术在近年来比较成熟&#xff0c;不同车型的操作步骤可能略有不同&#xff0c;但基本的流程应该是通用的&#xff0c;不会因为时间变化而有大的改变。 移动管家汽车一键启动无钥匙进入系统通常是通过携带钥匙靠近车辆&#xff0c;然后触摸门把…

Android之APP更新(通过接口更新)

文章目录 前言一、效果图二、实现步骤1.AndroidManifest权限申请2.activity实现3.有版本更新弹框UpdateappUtilDialog4.下载弹框DownloadAppUtils5.弹框背景图 总结 前言 对于做Android的朋友来说&#xff0c;APP更新功能再常见不过了&#xff0c;因为平台更新审核时间较长&am…

AI触手可及 | 基于函数计算玩转AI大模型

AI触手可及 | 基于函数计算玩转AI大模型 基于函数计算部署AI大模型的优势方案架构图像生成 - Stable Diffusion WebUI部署操作 释放资源部署总结体验反馈 在生成式AI技术加速迭代的浪潮下&#xff0c;百亿级参数的行业大模型正推动产业智能化范式转移。面对数字化转型竞赛&…

DDD该怎么去落地实现(4)多对多关系

多对多关系的设计实现 如题&#xff0c;DDD该如何落地呢&#xff1f;前面我通过三期的内容&#xff0c;讲解了DDD落地的关键在于“关系”&#xff0c;也就是通过前面我们对业务的理解先形成领域模型&#xff0c;然后将领域模型的原貌&#xff0c;形成程序代码中的服务、实体、…

【补阙拾遗】排序之冒泡、插入、选择排序

炉烟爇尽寒灰重&#xff0c;剔出真金一寸明 冒泡排序1. 轻量化情境导入 &#x1f30c;2. 边界明确的目标声明 &#x1f3af;3. 模块化知识呈现 &#x1f9e9;&#x1f4ca; 双循环结构对比表★★★⚠️ 代码关键点注释 4. 嵌入式应用示范 &#x1f6e0;️5. 敏捷化巩固反馈 ✅ …

前端面试题---小程序跟vue的声明周期的区别

1. 小程序生命周期 小程序的生命周期主要分为 页面生命周期 和 应用生命周期。每个页面和应用都有自己独立的生命周期函数。 应用生命周期 小程序的应用生命周期函数与全局应用相关&#xff0c;通常包括以下几个钩子&#xff1a; onLaunch(options)&#xff1a;应用初始化时触…

【芯片设计】NPU芯片前端设计工程师面试记录·20250227

应聘公司 某NPU/CPU方向芯片设计公司。 小声吐槽两句,前面我问了hr需不需要带简历,hr不用公司给打好了,然后我就没带空手去的。结果hr小姐姐去开会了,手机静音( Ĭ ^ Ĭ )面试官、我、另外的hr小姐姐都联系不上,结果就变成了两个面试官和我一共三个人在会议室里一人拿出…