Vue 基础详解 | 系统性学习 | 无知的我费曼笔记

news2025/1/11 16:49:44

无知的我正在复盘Vue
该笔记特点是

  • 重新整理了涉及资料的一些语言描述、排版而使用了自己的描述
  • 对一些地方做了补充说明。比如解释专有名词、类比说明、对比说明、注意事项
  • 提升了总结归纳性。尽可能在每个知识点上都使用一句话 || 关键词概括
  • 更注重在实际上怎么应用
  • 提出并回答了一些问题

下面的图片是我用思维导图总结的vue知识
vue的学习介绍

从指令到过滤器

Vue 基础

      • 一 什么是 Vue
        • 1.Vue简介
        • 2.MVVM 模式的实现者——双向数据绑定模式
        • 3.其它 MVVM 实现者
        • 4.为什么要使用 Vue.js
        • 5.Vue.js 的两大核心要素
        • 1)数据驱动
        • 2)组件化
      • 二 快速开始
      • 三 插值表达式
        • 1.插值表达式
        • 2.MVVM双向数据绑定:v-model
        • 3.事件绑定: v-on
        • 4.事件绑定 - 简化版:使用@替换v-on:
        • 5.属性绑定: v-bind
        • 6.v-once指令
        • 7.v-html
        • 8.v-text
      • 四 事件
        • 1.事件绑定范例
        • 2.参数传递
        • 3.停止鼠标事件
        • 4.事件修饰符
      • 五 vue改变内容——虚拟dom和diff算法
        • 1.插值表达式的方式
        • 2.计算属性:computed
          • 1) 什么是计算属性
          • 2) 计算属性与方法的区别
          • 3) 测试效果
          • 4) 结论
        • 3.watch的用法:监控
      • 六 vue改变样式
        • 1.class的动态绑定
        • 2.加入computed
        • 3.双向绑定的体现
        • 4.多个样式的操作
        • 5.通过style设置样式
        • 6.使用computed设置样式
        • 7.设置style属性的多个样式
      • 七 vue中的语句
        • 1.分支语句
        • 2.循环语句
      • 八、总结

一 什么是 Vue

1.Vue简介

Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式的js框架,发布于 2014 年 2 月。

与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。

Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库(如:vue-routervue-resourcevuex)或既有项目整合。 MVC

2.MVVM 模式的实现者——双向数据绑定模式

  • Model:模型层,在这里表示 JavaScript 对象
  • View:视图层,在这里表示 DOM(HTML 操作的元素)
  • ViewModel:连接视图和数据的中间件,Vue.js 就是 MVVM 中的 ViewModel 层的实现者

image-20221210182101335

在 MVVM 架构中,是不允许 数据视图 直接通信的,只能通过 ViewModel 来通信,而 ViewModel 就是定义了一个 Observer 观察者

  • ViewModel 能够观察到数据的变化,并对视图对应的内容进行更新
  • ViewModel 能够监听到视图的变化,并能够通知数据发生改变

至此,我们就明白了,Vue.js 就是一个 MVVM 的实现者,他的核心就是实现了 DOM 监听数据绑定

3.其它 MVVM 实现者

  • AngularJS
  • ReactJS
  • 微信小程序

4.为什么要使用 Vue.js

  • 轻量级,体积小是一个重要指标。Vue.js 压缩后有只有 20多kb (Angular 压缩后 56kb+,React 压缩后 44kb+
  • 移动优先。更适合移动端,比如移动端的 Touch 事件
  • 易上手,学习曲线平稳,文档齐全
  • 吸取了 Angular(模块化)和 React(虚拟 DOM)的长处,并拥有自己独特的功能,如:计算属性
  • 开源,社区活跃度高

5.Vue.js 的两大核心要素

1)数据驱动

img

当你把一个普通的 JavaScript 对象传给 Vue 实例的 data 选项,Vue 将遍历此对象所有的属性,并使用 Object.defineProperty 把这些属性全部转为 getter/setter

Object.defineProperty 是 ES5 中一个无法 shim 的特性,这也就是为什么 Vue 不支持 IE8 以及更低版本浏览器。

这些 getter/setter 对用户来说是不可见的,但是在内部它们让 Vue 追踪依赖,在属性被访问和修改时通知变化。这里需要注意的问题是浏览器控制台在打印数据对象时 getter/setter 的格式化并不同,所以你可能需要安装 vue-devtools 来获取更加友好的检查接口。

每个组件实例都有相应的 watcher 实例对象,它会在组件渲染的过程中把属性记录为依赖,之后当依赖项的 setter 被调用时,会通知 watcher 重新计算,从而致使它关联的组件得以更新。

2)组件化

  • 页面上每个独立的可交互的区域视为一个组件
  • 每个组件对应一个工程目录,组件所需的各种资源在这个目录下就近维护
  • 页面不过是组件的容器,组件可以嵌套自由组合(复用)形成完整的页面

二 快速开始

1.在页面引入vue的js文件即可。

<script src="https://cdn.bootcss.com/vue/2.5.17-beta.0/vue.min.js"></script>

注意:cdn是一种加速策略,能够快速的提供js文件。 //相当于服务器镜像。解决因网络问题而获取资源文件慢的问题。

2.在页面中绑定vue元素

创建一个div,id是app
<div id="app"></div>

3.创建vue对象,设计对象的内容

其中该vue对象,绑定了页面中id是app的那个div

<script>
		new Vue({
			el:"#app",
			data:{
				title:"hello vue!",
                  args1:"hi!",
                 age:18,
                flag:true
			}
		});
</script>

4.在页面的元素中使用插值表达式来使用vue对象中的内容

<div id="app">
	{{ title }}
</div>

三 插值表达式

插值表达式的作用是

在View中获得Model中的内容,插值表达式不能写在HTML中,不能作为值的部分。

1.插值表达式

<div id="app">
			{{title}}
			{{[1,2,3,4][2]}}
			{{ {"name":"xiaoyu","age":20}.age }}
			{{ sayHello()}}
</div>			
new Vue({
				el:"#app",
				data:{
					title:"hello world!"
				},
				methods:{
					sayHello:function(){
						return "hello vue";
					}
				}
			});

2.MVVM双向数据绑定:v-model

<div id="app">
	<input type="text" v-model="title" />		
</div>

3.事件绑定: v-on

<input type="text" v-on:input="changeTitle" />

v-on叫绑定事件,事件是input,响应行为是changeTitle。

也就是说,当input元素发生输入事件时,就会调用vue里定义的changeTitle方法

new Vue({
				el:"#app",
				data:{
					title:"hello world!"
				},
				methods:{
					sayHello:function(){
						return "hello vue";
					},
					changeTitle:function(){
						console.log("ct");//往日志里写
					}
				}
			});

如果在method里要想使用当前vue对象中的data里的内容,必须加上this.

changeTitle:function(event){
	this.title = event.target.value;
}

event.target.value == 当前事件的对象(input元素)的value值。

注意:此时的this指的是当前vue对象。

4.事件绑定 - 简化版:使用@替换v-on:

<input type="text" @input="changeTitle" />

5.属性绑定: v-bind

要想在html的元素中的属性使用vue对象中的内容,那么得用v-bind进行属性绑定

<a v-bind:href="link">baidu</a>
可以缩写成 冒号
<a :href="link">baidu</a>

html里的所有属性,都不能使用插值表达式,如下

<a href="{{link}}">baidu</a>

new Vue({
	el:"#app",
	data:{
		title:"hello world!",
		link:"http://www.baidu.com"
    },
    ...

6.v-once指令

指明此元素的数据只获取一次,之后数据内容的修改不影响此元素。

<p v-once>{{title}}</p>

7.v-html

就好比是innerHTML

<p v-html="finishedlink"></p>
new Vue({
		el:"#app",
		data:{
			title:"hello world!",
		    link:"http://www.baidu.com",
			finishedlink:"<a href='http://www.baidu.com'>百度</a>"
				},
    	...

8.v-text

纯文本输出内容

<p v-text="finishedlink"></p>

四 事件

1.事件绑定范例

范例一:

<div id="app">
			<button type="button" v-on:click="increase">click</button>
			<p>
				{{counter}}
			</p>
new Vue({
		el:"#app",
		data:{
			counter:0		
		},
		methods:{
			increase:function(){
				this.counter++;
		},
		...

范例二:

<p v-on:mousemove="mo">mooooooo</p>
mo:function(event){
		console.log(event);
}

范例三:

<p v-on:mousemove="mo">
		mx:{{x}}
		my:{{y}}
</p>
new Vue({
		el:"#app",
		data:{
			counter:0,
			x:0,
			y:0,
		},
		methods:{
			increase:function(){
				this.counter++;
			},
			mo:function(event){
				this.x = event.clientX,
				this.y = event.clientY
			}
		}	
});

2.参数传递

<button type="button" v-on:click="increase(2)">click</button>
			...	
			methods:{

					increase:function(step){

						this.counter+=step;

					},
			...

传多个参数:

<button type="button" v-on:click="increase(2,event)">click</button>
			...
			methods:{
					increase:function(step,event){
						this.counter+=step;
			},
			...

3.停止鼠标事件

<p v-on:mousemove="mo">
	mx:{{x}}
	my:{{y}}
	---<span v-on:mousemove="dummy">停止鼠标事件</span>
</p>
dummy:function(event){
		event.stopPropagation();
}

另一种方式:

<span v-on:mousemove.stop>停止鼠标事件</span>

4.事件修饰符

输入回车键时提示

<input type="text" v-on:keyup.enter="alertE"/>

alertE应该还是引用了vue的东西,所以双引号里面都是这样的

输入空格时提示

<input type="text" v-on:keyup.space="alertE"/>

五 vue改变内容——虚拟dom和diff算法

1.插值表达式的方式

范例一:

{{ count>10?"大于10","小于10"}}

范例二:

<p>
	{{result}}
</p>
new Vue({
		el:"#app",
		data:{
			counter:0,
			result:""
		},
		methods:{
			increase:function(step){
				this.counter+=step;
				this.result=this.counter>10?"大于10":"小于10"
			},
		}
});

???????

2.计算属性:computed

1) 什么是计算属性

计算属性的重点突出在 属性 两个字上(属性是名词),首先它是个 属性 其次这个属性有 计算 的能力(计算是动词),这里的 计算 就是个函数;

简单点说,它就是一个能够将计算结果缓存起来的属性(将行为转化成了静态的属性),仅此而已;

2) 计算属性与方法的区别

完整的 HTML

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>布局篇 计算属性</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>

<div id="vue">
    <p>调用当前时间的方法:{{currentTime1()}}</p>
    <p>当前时间的计算属性:{{currentTime2}}</p>
</div>

<script type="text/javascript">
    var vm = new Vue({
        el: '#vue',
        data: {
            message: 'Hello Vue'
        },
        methods: {
            currentTime1: function () {
                return Date.now();
            }
        },
        computed: {
            currentTime2: function () {
                this.message;
                return Date.now();
            }
        }
    });
</script>
</body>
</html>
  • methods:定义方法,调用方法使用 currentTime1(),需要带括号
  • computed:定义计算属性,调用属性使用 currentTime2,不需要带括号(即不带括号地调用不代表就是data中的数据);this.message 是为了能够让 currentTime2 观察到数据变化而变化

注意:methodscomputed 里不能重名,

3) 测试效果

仔细看图中说明,观察其中的差异

4) 结论

引出问题 调用方法时,每次都需要进行计算,既然有计算过程则必定产生系统开销,那如果这个结果是不经常变化的呢?

此时就可以考虑将这个结果缓存起来,采用计算属性可以很方便的做到这一点;计算属性的主要特性就是为了将不经常变化的计算结果进行缓存,以节约我们的系统开销

3.watch的用法:监控

watch用于监控参数的变化,并调用函数

new Vue({
				el:"#app",
				data:{
					counter:0,
					result:""
				},
				methods:{
					increase:function(step){
						this.counter+=step;
						//this.result=this.counter>10?"大于10":"小于10"
					},
					getResult:function(){
						return this.counter>10?"大于10":"小于10"
					}
				},
				computed:{
					getResultComputed:function(){
						return this.counter>10?"大于10":"小于10"
					}
				},
				watch:{
					counter:function(newVal,oldVal){
						this.result=newVal>10?"大于10":"小于10"
					}
				}
			});

其中newVal是能获得属性改变后的值,oldVal是属性改变前的值。如下

image-20221209123852600

watch的高端用法:
一秒后让count归为0,体现了vue的双向绑定

watch:{
	counter:function(newVal,oldVal){
		this.result=newVal>10?"大于10":"小于10";
		var vm = this;//当前data
		setTimeout(function(){
			vm.counter = 0;
		},1000);		
	}
}

引出问题 为什么不在方法中直接使用this?

这可能是因为方法的作用域的关系

六 vue改变样式

1.class的动态绑定

v-bind:class="{red:attachRed}"

键名是类名,键值是布尔,如果是true,则将指定的类名绑定在元素上,如果是false,则不绑定。

<head>
		<meta charset="UTF-8">
		<title>下午</title>
		<style>
			.demo{
				width:100px;
				height:100px;
				background-color:gray;
				display:inline-block;
				margin:10px;
			}
			.red{background-color: red;}
			.green{background-color: green;}
			.blue{background-color: blue;}
			
		</style>
	</head>
	<body>
		<div id="app">
			{{attachRed}}
			<div class="demo" @click="attachRed=!attachRed" v-bind:class="{red:attachRed}">				</div>
			<div class="demo"></div>
			<div class="demo"></div>
		</div>
		<script src="https://cdn.bootcss.com/vue/2.5.17-beta.0/vue.min.js"></script>
		<script>
			new Vue({
				el:"#app",
				data:{
					attachRed:false
				}
			});
		</script>
	</body>

2.加入computed

<div class="demo" :class="divClasses"></div>
new Vue({
				el:"#app",
				data:{
					attachRed:false
				},
				computed:{
					divClasses:function(){
						return {//返回一个json对象
							red:this.attachRed,
							blue:!this.attachRed
						}
					}
					
				}
	});

3.双向绑定的体现

在input中输入颜色,就可以设置div的class

<div id="app">
			<input type="text" v-model="color"/>
			{{attachRed}}
			<div class="demo" @click="attachRed=!attachRed" v-bind:class="{red:attachRed}"></div>
			<div class="demo"></div>
			<div class="demo" :class="divClasses"></div>
			<div class="demo" :class="color"></div>
		</div>
		
		<script>
			new Vue({
				el:"#app",
				data:{
					attachRed:false,
					color:"green"
				},
              ...

4.多个样式的操作

.red{background-color: red;color: white;}
<div class="demo" :class="[color,{red:attachRed}]">hahaha</div>

5.通过style设置样式

<div class="demo" :style="{backgroundColor:color}"></div>

设置div的style属性的值,style里放json对象,键是驼峰式写法,值是变量color

6.使用computed设置样式

<div class="demo" :style="myStyle"></div>
<input type="text" v-model="width"/>

	new Vue({
				el:"#app",
				data:{
					attachRed:false,
					color:"green",
					width:100
				},
				computed:{
					divClasses:function(){
						return {//返回一个json对象
							red:this.attachRed,
							blue:!this.attachRed
						}
					},
					myStyle:function(){
						return {
							backgroundColor:this.color,
							width:this.width+"px"
						}
					}
					
				}
			});
		</script>

7.设置style属性的多个样式

<div class="demo" :style="[myStyle,{height:width*2+'px'}]"></div>

七 vue中的语句

1.分支语句

v-if

<div v-if="temp">!!!</div>	

当temp的值是true时,div中的内容才会显示

v-else-if

就是在else里再嵌套一个if

<div id="app">
    <div v-if="temp">看到我了!</div>       当temp是true时能显示
        
    <div v-else-if="temp1">!!!!前方高能!!!!</div>  当temp是false时,且temp1是true时能显示

    <div v-else="temp">看到他了!</div>  当temp是false时,且temp1是false时能显示

    <button type="button" @click="temp=!temp">点我</button>

</div>
</body>

<script src="https://cdn.bootcss.com/vue/2.6.10/vue.js"></script>
<script>

    new Vue({
        el:'#app',
        data:{
            temp:false,
            temp1:false
        }
    });
</script>
</html>

v-else:就是v-if的对立面

v-show

用法上和v-if是相同的。也就是说 v-show=“布尔值变量” 是true的时候,就会显示内容,是false的时候就不会显示内容,但是v-show改变的是元素的样式,不显示内容时样式是: display是none,而v-if是直接让元素消失和直接添加元素,效率上,v-show更高。

所以实际上是让该元素的display属性为none,隐藏的效果。所以性能更好。这是一道面试题

<div id="app">
			<p v-if="show">hahah</p>
			<p v-else>hohoho</p>
			<p v-show="show">hehehe</p>
			<input type="button" @click="show=!show" value="dianwo"/>
		</div>
		<script src="https://cdn.bootcss.com/vue/2.5.17-beta.0/vue.min.js"></script>
		<script>
			new Vue({
				el:"#app",
				data:{
					show:false
				}
			});
		</script>

通过模板标签对多个元素进行同一的if和else管理

就是要不一起显示,要不一起不显示

<template v-if="show">
				<h1>heading</h1>
				<p>inside text</p>
			</template>

2.循环语句

普通的for

<body>
		<div id="app">
			<ul>
				<li v-for="str in args">
					{{str}}
				</li>
			</ul>
		</div>
		<script src="https://cdn.bootcss.com/vue/2.5.17-beta.0/vue.min.js"></script>
		<script>
			new Vue({
				el:"#app",
				data:{
					args:["a","b","c","d"]
				}
			});
		</script>
	</body>

带着索引的for

<ul>
	<li v-for="(str,i) in args" :key="i">
		{{str}}{{i}}
	</li>
</ul>

此时的i就是每次循环的循环变量 ,从0开始一直到元素个数-1

使用templete实现循环

<template v-for="(str,i) in args":key="i">
		<p>{{str}}{{i}}</p>
</template>

遍历一个对象

下面是两种用法

1 将数组的值拿出来

2 将key、value、索引拿出来

<template v-for="person in persons">
	<p>
		<span v-for="value in person">
			{{value}}
		</span>
	</p>
	<p>
		<span v-for="(v,k,i) in person">
			{{k}}:{{v}}:{{i}}==== //!这三个参数接收的是值、键、索引。参数名可以任意取
		</span>
	</p>
</template>
			
<script>
	new Vue({
		el:"#app",
		data:{
			args:["a","b","c","d"],
			persons:[
				{name:"xy",age:20,color:"red"},
				{name:"yh",age:18,color:"green"}
			]
		}
	});
</script>

遍历一个对象数组:嵌套的for循环

<ul>
    <li v-for=" student in students">
        <span v-for="(v,k,i) in student">{{i}}--{{k}}--{{v}}--------------------</span>
    </li>
    
</ul>
new Vue({
    el:'#app',
    data:{
        args:[1,2,3,4,5,6],
        students:[
            {
                name:'xiaoming',
                age:20
            },
            {
                name:'xiaowang',
                age:21
            }
        ]
    }
});

循环的另一种用法

v-for="n in 10"   //可以在分页组件中使用
<nav>  
<ul class="pagination">
    <li>
      <a href="#" aria-label="Previous">
        <span aria-hidden="true">&laquo;</span>
      </a>
    </li>
    <!--======v-for====-->
    <li v-for="n in 10"><a href="#">{{n}}</a></li>
    
    <li>
      <a href="#" aria-label="Next">
        <span aria-hidden="true">&raquo;</span>
      </a>
    </li>
  </ul>
</nav>

八、总结

​ vue是以数据为驱动,渐进式的web框架,MVVM双向绑定,虚拟DOM为核心和diff算法,所谓的虚拟dom和diff算法,是指当页面内容发生变化时,只更新改变的部分,是通过虚拟dom和diff算法实现这样的操作,效率非常高。

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

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

相关文章

spring——AOP面向切面编程—— 自动代理——根据 Bean 名称创建代理对象根据切面中信息创建代理对象...

自动代理 在前面的案例中&#xff0c;所有目标对象(Target Bean)的代理对象(Proxy Bean)都是在 XML 配置中通过 ProxyFactoryBean 创建的。 但在实际开发中&#xff0c;一个项目中往往包含非常多的 Bean&#xff0c; 如果每个 Bean 都通过 ProxyFactoryBean 创建&#xff0c;那…

MySQL~InnoDB关键特性(插入缓存、俩次写、自适应哈希索引、异步IO

一般情况下&#xff0c;主键是行唯一的标识符。通常应用程序中行记录的插入顺序是按照主键递增的顺序进行插入的。因此&#xff0c;插入聚集索引一般是顺序的&#xff0c;不需要磁盘的随机读取。因为&#xff0c;对于此类情况下的插入&#xff0c;速度还是非常快的。 如果索引…

Selenium4+Python3系列 - 测试框架的设计与开发

框架搭建 整个框架的实现&#xff0c;大约也就1.5天&#xff0c;关于框架的开发并不是很难&#xff0c;主要难在测试报告增加失败自动截图功能和echart的饼子图统计功能&#xff0c;两者的整合花了近半天的时间吧。 效果&#xff1a; 1、核心思想 延续使用Page Object和Page …

RabbitMQ入门(三)消息应答与发布确认

前言&#xff1a; 消息应答与发布确认都是保证消息不丢失。而重复消费问题则是消息幂等性。&#xff08;之后会说幂等性&#xff09; 消息应答&#xff1a; 应答功能属于消费者&#xff0c;消费者在接收到消息并且处理该消息之后&#xff0c;告诉 rabbitmq 它已经处理了&…

深度学习——残差网络(ResNet)笔记

残差网络&#xff1a;经常使用的网络之一 1.随着神经网络的不断加深能改进精度吗&#xff1f; 不一定 ①蓝色五角星表示最优值&#xff0c;Fi闭合区域表示函数&#xff0c;闭合区域的面积代表函数的复杂程度。在这个区域能够找到一个最优的模型&#xff08;区域中的一个点表…

「重学JS」带你一文吃透作用域与闭包

前言 学习了这么久前端&#xff0c;发现自己对于基础知识的掌握并没有那么通透&#xff0c;于是打算重新学一遍JS&#xff0c;借用经济学的一句话&#xff1a;JS基础决定能力高度&#x1f926;&#x1f3fb; 基础很重要&#xff0c;只有基础好才会很少出 bug&#xff0c;大多数…

二叉树的性质

由于二叉树的结构特殊&#xff0c;会有一系列的数学性质 性质一&#xff1a;对于一棵二叉树&#xff0c;第i层的最大结点数量为 个&#xff0c;比如二叉树的第一层只有一个根结点&#xff0c;而二叉树的第三层可以有 个结点。 性质二&#xff1a;对于一棵深度为k的二叉树&am…

【Python】函数

文章目录1. 函数介绍2. 函数的定义与调用3. 函数参数4. 函数返回值5. 变量作用域6. 函数执行过程7. 链式调用8. 嵌套调用9. 函数递归10. 参数默认值11关键字参数1. 函数介绍 编程中的函数不同于数学中的函数&#xff1a; 数学上的函数&#xff0c;比如 y sin x&#xff0c;x…

Vue快速上门|了解MVVM

1.1、先了解下MVVM VUE是基于MVVM思想实现的,❓那什么是MVVM呢?—— MVVM,是Model-View-ViewModel的缩写,是一种软件架构模式。其核心思想就是分离视图、数据、逻辑,VUE框架解决了数据Model到视图View的双向绑定,我们只关注业务逻辑ViewModel即可,极大的提高的编程效率…

BadUSB超详细制作, 实现CobaltStrike远控上线

前言 在2014年美国黑帽大会上&#xff0c;安全研究人员JakobLell和独立安全研究人员Karsten Nohl展示了他们称为“BadUSB”的攻击方法&#xff0c;这种攻击方法让USB安全和几乎所有和USB相关的设备(包括具有USB端口的电脑)都陷入相当危险的状态 现在的USB设备很多&#xff0c…

高级篇之ENC1当作采集卡使用方案推荐

高级篇之ENC1当作采集卡使用0 背景&#xff1a;1 准备工作2 连接示意图3 配置步骤&#xff1a;3.1 在笔记本电脑上安装NDI4工具3.2 ENC1设备连接3.3 配置电脑的USB网卡的IP地址3.4 配置ENC1设备3.5 打开NDI工具的虚拟输入功能0 背景&#xff1a; HDMI视频采集卡分为内嵌式采集…

【GCC编译优化系列】宏定义名称与函数同名是一种什么骚操作?

作者简介 *架构师李肯&#xff08;全网同名&#xff09;**&#xff0c;一个专注于嵌入式IoT领域的架构师。有着近10年的嵌入式一线开发经验&#xff0c;深耕IoT领域多年&#xff0c;熟知IoT领域的业务发展&#xff0c;深度掌握IoT领域的相关技术栈&#xff0c;包括但不限于主流…

​全网最牛的Fiddler系列文章(一):fiddler的介绍及安装​

Fiddler(1)&#xff1a;fiddler的介绍及安装 Fiddler简介 Fiddler是比较好用的web代理调试工具之一&#xff0c;它能记录并检查所有客户端与服务端的HTTP/HTTPS请求&#xff0c;能够设置断点&#xff0c;篡改及伪造Request/Response的数据&#xff0c;修改hosts&#xff0c;限…

【UEFI实战】Redfish的BIOS实现1

Redfish的BIOS实现 EDK2提供了Redfish框架&#xff0c;用来实现带外的BIOS配置&#xff0c;其基本框架如下&#xff1a; 通过RedfishPkg中提供的Driver&#xff0c;可以实现BIOS与BMC或者其它的软件进行通信。它主要分为两个部分&#xff0c;分别是Client和Foundation。Client…

[论文解析]DREAMFUSION: TEXT-TO-3D USING 2D DIFFUSION

code links&#xff1a;dreamfusion3d.github.io 文章目录OverviewWhat problem is addressed in the paper?What is the key to the solution?What is the main contribution?What can we learn from ablation studies&#xff1f;Potential fundamental flaws; how this w…

MATLB|基于粒子群算法的能源管理系统EMS(考虑光伏、储能 、柴油机系统)

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️❤️&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清…

原子操作类之18罗汉增强

原子操作类之18罗汉增强 是什么 都是java.util.concurrent.atomic包下的 有红框圈起来的&#xff0c;也有蓝框圈起来的&#xff0c;为什么&#xff1f; 阿里巴巴Java开发手册 为什么说18罗汉增强&#xff0c;却只有16个 再分类 基本类型原子类 AtomicInteger AtomicBoolea…

wpa_supplicant工具移植到嵌入式设备

1、wpa_supplicant源码下载 (1)源码下载地址&#xff1a;http://w1.fi/releases/&#xff1b; (2)本文是以wpa_supplicant-2.6.tar.gz版本进行移植&#xff1b; 2、编译openssl 2.1、确定适配的openssl版本 Optional libraries for EAP-TLS, EAP-PEAP, and EAP-TTLS: - OpenS…

【LeetCode】1827. 最少操作使数组递增

题目描述 给你一个整数数组 nums &#xff08;下标从 0 开始&#xff09;。每一次操作中&#xff0c;你可以选择数组中一个元素&#xff0c;并将它增加 1 。 比方说&#xff0c;如果 nums [1,2,3] &#xff0c;你可以选择增加 nums[1] 得到 nums [1,3,3] 。 请你返回使 nums …

ESXi8.0中NVME硬盘不识别解决方法1,设置直通

目录 1.前言 2.直通设置 3.槽点 1.前言 ESXi8.0删除了很多老版本的硬件的驱动程序&#xff0c;导致NVME1.3及更低协议的固态硬盘均无法被ESXi直接识别正如我手头准备了尚好的服务器专用PM983A却无法识别。本着不折腾先熟悉ESXi8.0的思路另外找了一块盘装了ESXi的系统。本以为…