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

2024前端面试(内容持续更新)

Vue篇

data为什么是个函数?

        在‌Vue中,‌data必须是一个‌函数,这是因为当data是函数时,每个组件实例化时都会调用该函数,返回一个新的数据对象,从而保证每个组件实例拥有独立的数据,避免数据冲突和不正确的状态更新。‌

        具体来说,如果data是一个对象字面量,多个组件实例会共享同一个数据对象,导致数据冲突和不正确的状态更新。而当data是一个函数时,每次创建组件实例时都会调用该函数,返回一个新的数据对象,每个组件实例都有自己的数据对象,互不干扰。这样,改变其中一个组件的状态不会影响到其他组件。‌

优点:
  1. 避免数据冲突:通过将data定义为函数,每个组件实例都会获得一个独立的数据对象,避免了数据冲突和不正确的状态更新。‌
  2. 更好的封装和组件化:将data定义为函数可以更好地封装组件的状态,使得组件的逻辑更加清晰和模块化,也使得组件的测试更加容易。‌
  3. 提高性能:由于data是函数而不是对象字面量,Vue可以更好地跟踪依赖关系和变化,从而提高响应性和性能。

生命周期:

Vue2的生命周期: 
  •  beforeCreate:实例初始化之后,数据观测(data observer)和事件/watcher 设置之前被调。
  • created:实例创建完成后被立即调用。在这一步,实例已完成以下的配置:数据观测(data observer),属性和方法的运算,watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。

  • beforeMount:模板编译/挂载之前被调用。在这之前,$el 属性还不存在。

  • mounted:el 被新创建的 vm.$el 替换,并挂载到实例上去之后调用。一旦挂载完成,实例就处于可用状态。

  • beforeUpdate:数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。

  • updated:由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。

  • activated:在使用 vue-router 时,路由变化(切换到当前组件)时被调用。

  • deactivated:在使用 vue-router 时,路由变化(离开当前组件)时被调用。

  • beforeDestroy:实例销毁之前调用。在这一步,实例仍然完全可用。

  • destroyedVue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑,所有的事件监听器会被移除,所有的子实例也会被销毁。

Vue3的生命周期: 
  •  setup - Vue2中的beforecreate和created被setup方法本身所替代
  • onBeforeMount - 组件挂载之前调用。

  • onMounted - 组件挂载之后调用。

  • onBeforeUpdate - 组件更新之前调用。

  • onUpdated - 组件更新之后调用。

  • onBeforeUnmount - 组件卸载之前调用。

  • onUnmounted - 组件卸载之后调用。

  • onActivated - 组件被keep-alive激活时调用。

  • onDeactivated - 组件被keep-alive停用时调用。

  • onErrorCaptured - 捕获子组件的错误时调用。

父子组件生命周期:

创建时:父beforeCreate -> 父created -> 父beforeMount -> 子beforeCreate -> 子created -> 子beforeMount -> 子mounted -> 父mounted

销毁时:父beforeUpdated -> 子beforeUpdated -> 子updated -> 父updated

父子组件传参和事件:

子组件
<template><div class="hello"><div>{{ msg }} 子组件</div><button @click="add">加一</button><button @click="add2">加二</button></div></template><script>
export default {name: 'HelloWorld',props: {msg: String},data() {return {child: '儿子'}},methods: {add() {this.$emit('child')// 触发父组件的自定义事件},add2() {this.$emit('child', 2)// 触发父组件的自定义事件},}
}
</script><style scoped></style>
 父组件
<template><div id="app"><!-- <img alt="Vue logo" src="./assets/logo.png"> --><h1>父组件</h1><HelloWorld :msg="AppMsg" @child="parentMethod" ref="childComponentRef" />{{ count }}<button @click="callChildMethod">调用子组件方法</button></div>
</template><script>
import HelloWorld from './components/HelloWorld.vue'export default {components: {HelloWorld},data() {return {AppMsg: "Welcome to Your Vue.js App",count: 1}},methods: {parentMethod(e) {if (e) {this.count += e} else {this.count++}},callChildMethod() {this.$refs.childComponentRef.add(); // 调用子组件的方法this.AppMsg = this.$refs.childComponentRef.child; // 访问子组件的属性},}
}
</script><style></style>

组件的封装:

父组件(使用被封装的组件)
<template><div id="map-container">
<!-- 使用组件 --><mapItem :mapData="mapData" :isFullScreen="isFullScreen" ref="mapIndex" @pointermove="clickPoint"><divclass="map-item"v-for="(item, index) in mapData":key="index":class="{ active: index + 1 === parseInt(pointName) }">插槽内容</div></mapItem></div>
</template>
<script>
import mapItem from "@/components/map/index.vue";//引用组件
export default {name: "map",data() {return {pointName: "",//传递给组件的数据isFullScreen: true,mapData: [//传递给组件的数据],};},components: {mapItem,//声明组件},mounted() {},methods: {clickPoint(e) {this.pointName = e;},},};
</script>
<style scoped>
#map-container {height: 100%;
}
#map-container {display: flex;
}
.margin-top {margin-top: 10px;margin-left: 5px;
}
::v-deep .el-descriptions-item {line-height: 0.85 !important;font-size: 11px;
}
.map-item {border: 1px solid #a3cffe;border-bottom: 0;
}
.map-item:last-child {border-bottom: 1px solid #a3cffe;
}
.active {background-color: #a3cffe;
}
</style>
组件 
<template><div class="map-container"><div class="map-content"></div><div class="map-right" v-if="$slots.default">
<!-- 默认插槽 --><slot /></div></div>
</template><script>export default {name: "Map",props: {//接受父组件传来的数据mapData: Array,isFullScreen:Boolean,},data() {return {pointName: "",};},mounted() {},methods: {changePoint(e) {this.pointName = e;this.$emit('pointermove',this.pointName)},},
};
</script><style scoped>
.map-container {height: 100%;width:100%;
}
.map-container {display: flex;
}
.map-container .map-content {flex: 8;
}
.map-container .map-right {flex: 2;
}</style>

​​​​​​​Vue常见问题(一)组件的使用-CSDN博客

::v-deep和:deep()

在Vue中,::v-deep 和 :deep() 都用于修改CSS选择器的作用域。 区别在于:

  • :deep() 是一个伪类选择器,可以用于将CSS规则应用于当前组件及其所有子组件中匹配选择器的元素。例如,.foo :deep(.bar)会选择包含class为"bar"的元素的所有嵌套层次结构。
  • ::v-deep 是一个特殊的深度作用选择器,它只在scoped样式中起作用,并且可以将CSS规则应用于当前组件及其所有子组件中匹配选择器的元素。例如,.foo::v-deep .bar 会选择包含class为"bar"的元素的所有嵌套层次结构,但仅对 .foo组件的样式生效。

$.nextTick

为什么使用nextTick

因为 vue 采用的异步更新策略,当监听到数据发生变化的时候不会立即去更新DOM,而是开启一个任务队列,并缓存在同一事件循环中发生的所有数据变更;这种做法带来的好处就是可以将多次数据更新合并成一次,减少操作DOM的次数,如果不采用这种方法,假设数据改变100次就要去更新100次DOM,而频繁的DOM更新是很耗性能的。

nextTick的作用和使用
  • nextTick 接收一个回调函数作为参数,并将这个回调函数延迟到DOM更新后才执行;
  • 使用场景:想要操作 基于最新数据生成的DOM 时,就将这个操作放在 nextTick 的回调中;
new Vue({data() {return {message: 'Hello, Jock!!'}},mounted() {this.message = 'Hi,Tom'this.$nextTick(() => {// 在DOM更新之后执行的操作console.log(this.$el.textContent) // 输出:"Hi,Tom"})}
})

Vue.set

一般定义在data里的数据,由于双向绑定,操作后会发生改变,但是对于复杂数据类型中的值的改变Vue不能检测,所以我们需要用到Vue.set来实现。

为什么要使用Vue.set

        因为 value 数据发生变化的时候,Vue 没有立刻去更新 DOM ,而是将修改数据的操作放在了一个异步操作队列中,如果一直修改相同数据,异步操作队列还会进行去重,等待同一事件循环中的所有数据变化完成之后,会将队列中的事件拿来进行处理,进行 DOM 的更新. 

Vue.set的使用: 

Vue.set( target, key, value )
target:要更改的数据源(可以是对象或者数组)
key:要更改的具体数据
value :重新赋的值

Vuex

官方文档:开始 | Vuex

v-show和v-if

  •  v-show是通过控制dom元素的display属性来控制元素的显示与隐藏;而v-if是直接在dom树中添加或者删除元素来控制元素的显示与隐藏。
  • 切换条件时,v-if控制的元素会进行销毁和重建,而v-show控制的元素只是进行css切换。
  • 如果进行不断的条件切换时,因为v-if会对元素进行销毁和重建,所以消耗的性能更大;v-show只是对css进行变更,所以消耗的性能更小。

Vue2和Vue3的区别和优点

Vue2和Vue3的区别 

Vue 2和Vue 3之间的主要区别体现在多个方面,包括底层API、语法、根节点、兼容性、生态支持以及开发工具的支持。以下是详细的对比:

底层API和响应式原理
  • Vue 2:使用Object.defineProperty来实现响应式数据,这种方式可以劫持对象的属性,但对于数组和对象的变化处理不够灵活,新增属性需要手动处理才能实现响应式。
  • Vue 3:采用Proxy来实现响应式数据,可以劫持整个对象,递归返回属性的值的代理,从而实现对整个对象的深度监听,包括属性的新增和删除。
根节点
  • Vue 2:必须有一个根节点。
  • Vue 3:可以没有根节点,多个根节点会被默认包裹在一个Fragment虚拟标签中,这有助于减少内存使用。
兼容性
  • Vue 2:不支持IE8及以下版本。
  • Vue 3:不支持IE11及以下版本。
语法和API
  • Vue 2:采用选项式API,将数据和函数集中在一个对象中处理,这种方式在复杂项目中不利于代码的阅读和维护。
  • Vue 3:采用组合式API,将同一个功能的代码集中在一起处理,使得代码更加有序,有利于代码的书写和维护。
开发工具
  • Vue 2:主要使用Vetur插件进行代码高亮和语法提示,Vue 2 Snippets提供语法片段支持。
  • Vue 3:推荐使用Volar插件进行代码高亮和语法提示,Vue 3 Snippets提供更好的Vue 3支持。
生态支持
  • Vue 2:由JavaScript编写,对TypeScript的支持相对较弱。
  • Vue 3:由TypeScript重写,提供更好的TypeScript支持,有利于使用TypeScript进行开发。
生命周期

Vue3.0中 Composition API 形式的生命周期钩子,与Vue2.x中钩子对应关系:

  • beforeCreate===>setup()
  • created=======>setup()
  • beforeMount ===>onBeforeMount
  • mounted=======>onMounted
  • beforeUpdate===>onBeforeUpdate
  • updated =======>onUpdated
  • beforeUnmount ==>onBeforeUnmount
  • unmounted =====>onUnmounted

插槽

        插槽就是子组件中的提供给父组件使用的一个占位符,用slot标签表示,父组件可以在这个占位符中填充任何模板代码,如 HTML、组件等,填充的内容会替换子组件的slot标签。简单理解就是子组件中留下个“坑”,父组件可以使用指定内容来补“坑”。vue插槽之插槽的用法及作用域插槽详解-CSDN博客

官方文档:https://v2.cn.vuejs.org/v2/guide/components-slots.html

数据双向绑定的原理

        Vue的双向绑定原理是通过数据劫持合发布者-订阅者模式来实现的,关键步骤如下:

  • 数据劫持:Vue组件初始化时,对 data 中的 item 进行递归遍历,会通过Object.defineProperty()方法来劫持对象的属性,这个方法可以对一个对象的属性进行定义或修改,包括定义getter和setter。这样,当这些被劫持的属性被读取或赋值时,就会触发相应的getter或setter函数。
  • 依赖收集:在编译器编译模板的过程中,如果模板中出现了某个数据对象的属性,那么Vue会为这个属性添加一个订阅者,这个过程就是依赖收集。这样,当数据变化时,就可以通知所有依赖于这个数据的订阅者进行更新。
  • 派发更新:当数据发生变化时,会触发setter函数,进而通知所有的订阅者。订阅者收到通知后,就会执行对应的更新函数,从而更新视图。
  • 视图更新:最后,Vue会根据更新函数的指示,对DOM进行操作,从而实现视图的更新。

页面白屏的原因

HTML篇

rem、em、vh、vw、px

em
  • em是相对长度单位,它是基于父元素的字体大小。如父元素的字体大小为14px,子元素字体大小为1.2em,显示出来的就是16px。
  • 当前对行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸(1em = 16px)。
  • 如果自身定义了font-size按自身来计算,整个页面内1em不是一个固定的值。
 rem

        rem也是相对单位,但它相对的只是HTML根元素font-size的值。 

 vw,vh
  • vw 就是根据窗口的宽度,分成100等份,100vw就表示满宽,50vw就表示一半宽。(vw 始终是针对窗口的宽),同理,vh则为窗口的高度。
  • 在pc端中,指的是浏览器的可视区域。
  • 在移动端中,指的则是布局视口。
 px

        绝对单位,页面按精确像素展示。

H5低版本浏览器如何处理

        使用html5.js插件兼容(推荐) 

<!--[if IE]>  
<script src=”http://html5shiv.googlecode.com/svn/trunk/html5.js”></script>  
<![endif]-->

CSS篇

CSS3新特性

  • 圆角(border-radius)
    div {border-radius: 10px;
    }
  • 阴影(box-shadow)
    div {box-shadow: 5px 5px 10px #888888;
    }
  • 渐变(gradient)
    div {background: linear-gradient(to right, red, yellow);
    }
  • 变换(transform)
    div:hover {transform: rotate(360deg);
    }
  • 动画(animation)
    @keyframes example {from {background-color: red;}to {background-color: yellow;}
    }div {animation-name: example;animation-duration: 4s;
    }
  • 多列布局(multi-column layout)
    div {column-count: 3;
    }
  • 过渡效果(transition)
    div:hover {transition: all 0.3s ease-in-out;
    }
  • 用户界面(UI)
    input[type="range"] {-webkit-appearance: none;background: #333;height: 10px;
    }
  • 2D/3D转换(transform)
    div {transform: translate(50px, 100px) rotate(360deg) scale(1.5);
    }
  • 文字效果(text-effects)
    div {text-shadow: 2px 2px 2px #888888;
    }
  • 伪元素(::before, ::after)、媒体查询(@media)、字体图标(@font-face)、网格布局、弹性布局、透明度等。

display: none 和 visibily: hidden 区别? 

  • display:none:隐藏对应的元素,整个元素消失不占空间。
  • visibily:hidden:隐藏对应的元素,元素还会占用空间。

JS篇

typeof和instanceof的区别是什么?

  • 作用:typeof检测数据类型,操作符返回一个字符串,表示未经计算的操作数的类型。instanceof检测对象之间的关联性,运算符用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。
  • 返回值:typeof返回小写字母字符串表示数据属于什么类型,instanceof返回布尔值。
  • 操作数:typeof是简单数据类型、函数或者对象,instanceof的左边必须是引用数据类型右边必须是函数。
  • 操作数数量:typeof是1个,instanceof是2个。
 typeof的用法
typeof "John"                // 返回 string
typeof 3.14                  // 返回 number
typeof false                 // 返回 boolean
typeof [1,2,3,4]             // 返回 object
typeof {name:'John', age:34} // 返回 object
typeof undefined // 'undefined'
typeof Symbol() // 'symbol'
typeof null // 'object'
instanceof 的用法
// 定义构建函数
let Car = function() {}
let benz = new Car()
benz instanceof Car // true
let car = new String('xxx')
car instanceof String // true
let str = 'xxx'
str instanceof String // false
instanceof的底层原理

        instanceof查找构造函数的原型对象是否在实例对象的原型链上,如果在返回true,如果不在返回false。 所以,只要右边变量的 prototype 在左边变量的原型链上即可。因此,instanceof 在查找的过程中会遍历左边变量的原型链,直到找到右边变量的 prototype,如果查找失败,则会返回 false。 

function instance_of(L, R) {//L 表示左表达式,R 表示右表达式 var O = R.prototype;   // 取 R 的显示原型 L = L.__proto__;  // 取 L 的隐式原型while (true) {    if (L === null)      return false;   if (O === L)  // 当 O 显式原型 严格等于  L隐式原型 时,返回truereturn true;   L = L.__proto__;  }
}

懒加载

        懒加载也就是延迟加载。当访问一个页面的时候,先把img元素或是其他元素的背景图片路径替换成一张大小为1*1px图片的路径(这样就只需请求一次,俗称占位图),只有当图片出现在浏览器的可视区域内时,才设置图片正真的路径,让图片显示出来。这就是图片懒加载。

 懒加载的原理
  • 页面中的img元素,如果没有src属性,浏览器就不会发出请求去下载图片,
  • 只有通过javascript设置了图片路径,浏览器才会发送请求。
  • 懒加载的原理就是先在页面中把所有的图片统一使用一张占位图进行占位,
  • 把真正的路径存在元素的“data-url”(这个名字起个自己认识好记的就行)属性里,要用的时候就取出来,再设置;
 懒加载的实现步骤
  • 首先,不要将图片地址放到src属性中,而是放到其它属性(data-original)中。
  • 页面加载完成后,根据scrollTop判断图片是否在用户的视野内,如果在,则将data-original属性中的值取出存放到src属性中。
  • 在滚动事件中重复判断图片是否进入视野,如果进入,则将data-original属性中的值取出存放到src属性中。
 懒加载的优点

        页面加载速度快、可以减轻服务器的压力、节约了流量,用户体验好。 

promise

对象的遍历

使用for...in循环: 
let obj = { a: 1, b: 2, c: 3 };
for (let key in obj) {if (obj.hasOwnProperty(key)) { // 确保属性是对象自身的而不是继承的console.log(key, obj[key]);}
}
 使用Object.keys()结合forEach
let obj = { a: 1, b: 2, c: 3 };
Object.keys(obj).forEach(key => {console.log(key, obj[key]);
});
使用Object.entries()结合for...of循环: 
let obj = { a: 1, b: 2, c: 3 };
for (let [key, value] of Object.entries(obj)) {console.log(key, value);
}
使用Object.getOwnPropertyNames()结合forEach: 

深拷贝和浅拷贝

let obj = { a: 1, b: 2, c: 3 };
Object.getOwnPropertyNames(obj).forEach(key => {console.log(key, obj[key]);
});

闭包

        闭包(closure)是一个函数以及它所引用环境的组合。创建闭包的常见方式是在一个函数内部创建另一个函数,而该内部函数可以访问外部函数的局部变量,即使外部函数已经执行完毕。【JavaScript】一文了解JS的闭包_js闭包-CSDN博客 

防抖与节流

  • 防抖:触发高频事件后 n 秒内函数只会执行一次,如果 n 秒内高频事件再次被触发,则重新计算时间。作用:防止事件连续或高频触发,让它只触发一次或者最后一次。
    var btn = document.querySelector("button");
    var tiemr = null;
    btn.onclick = function () {clearInterval(tiemr);tiemr = setTimeout(() => {console.log("触发了")}, 500)
    }
    
  • 节流:高频事件触发,但在 n 秒内只会执行一次,所以节流会稀释函数的执行频率。作用:降低事件触发的频率,比如1s内最多执行一次。
    let btn = document.querySelector("button");
    let jie = true;
    btn.onclick = function () {if (jie) {jie = false;console.log('触发了');setTimeout(() => {jie = true;}, 2000)}
    }	

axios的封装

        Axios 是一个基于 promise ​​​​​​​网络请求库。封装后我们只需要改变方法,请求路径,和请求返回的数据即可发送网络请求,省去大量重复的代码。

Axios封装代码
import axios from 'axios';// 创建axios实例
const service = axios.create({baseURL: process.env.VUE_APP_BASE_API, // api的base_urltimeout: 5000 // 请求超时时间
});// 请求拦截器
service.interceptors.request.use(config => {// 可以在这里添加请求头等信息// 例如:config.headers['Authorization'] = 'Bearer your-token';return config;},error => {// 请求错误处理console.log(error); // for debugPromise.reject(error);}
);// 响应拦截器
service.interceptors.response.use(response => {// 对响应数据做处理,例如只返回data部分const res = response.data;// 如果返回的状态码为200,说明成功,可以直接返回数据if (res.code === 200) {return res.data;} else {// 其他状态码都当作错误处理// 可以在这里对不同的错误码进行不同处理return Promise.reject({message: res.message || 'Error',status: res.code});}},error => {// 对响应错误做处理console.log('err' + error); // for debugreturn Promise.reject(error);}
);export default service;
Axios封装后的使用 
import service from '@/utils/request';// 获取用户列表
export function getUserList(params) {return service.get('/user/list', { params: params });
}// 创建用户
export function createUser(data) {return service.post('/user/create', data);
}// 更新用户信息
export function updateUser(id, data) {return service.put(`/user/update/${id}`, data);
}
  • 数组常用方法

  • push() - 在数组末尾添加一个或多个元素,并返回新的长度。

  • pop() - 删除数组的最后一个元素,并返回那个元素。

  • shift() - 删除数组的第一个元素,并返回那个元素。

  • unshift() - 在数组的开始添加一个或多个元素,并返回新的长度。

  • slice() - 选取数组的一部分,返回数组的一个浅拷贝。

  • splice() - 通过删除现有元素和/或添加新元素来更改一个数组的内容。

  • concat() - 连接两个或更多数组,并返回一个新数组。

  • join() - 将数组中的所有元素转换为一个字符串。

  • reverse() - 颠倒数组中元素的顺序。

  • sort() - 对数组的元素进行排序。

  • forEach() - 遍历数组中的每个元素并执行回调函数。

  • map() - 创建一个新数组,其结果是该数组中的每个元素是调用一次提供的函数后的返回值。

  • filter() - 创建一个新数组, 其包含通过所提供函数符合条件所有元素。

  • reduce() - 对数组中的每个元素执行一个由您提供的reducer函数(升序执行),将其结果汇总为单个返回值。

  • reduceRight() - 对数组中的每个元素执行一个由您提供的reducer函数(降序执行),将其结果汇总为单个返回值。

  • some() - 检测数组元素中是否有元素符合指定条件。

  • fill() - 使用一个固定值来填充数组。​​​​​​​

更多内容参考:JavaScript Array 对象 | 菜鸟教程 

Git篇

版本冲突和回退

网络综合篇

url请求的过程 

浏览器进程与网络进程的通信:‌浏览器进程通过进程间通信(IPC)将URL请求发送至网络进程。‌

本地缓存检查:‌网络进程首先检查本地缓存是否有所请求的资源。‌如果有缓存资源,‌则直接返回给浏览器进程;‌如果没有,‌则进入网络请求流程。‌

DNS解析:‌在进行网络请求前,‌需要进行DNS解析以获取请求域名的服务器IP地址。‌如果请求协议是HTTPS,‌还需要建立TLS连接。‌

TCP连接建立:‌利用IP地址和服务器建立TCP连接。‌

构建请求信息:‌连接建立后,‌浏览器端会构建请求行、‌请求头等信息,‌并将和该域名相关的Cookie等数据附加到请求头中,‌然后向服务器发送构建的请求信息。‌

服务器响应:‌服务器接收到请求信息后,‌根据请求信息生成响应数据(‌包括响应行、‌响应头和响应体等信息)‌,‌并发给网络进程。‌

响应头解析:‌网络进程接收响应行和响应头后,‌开始解析响应头的内容。‌如果发现返回的状态码是301或302,‌说明需要进行重定向到其他URL。‌

重定向处理:‌网络进程从响应头的Location字段里读取重定向的地址,‌然后发起新的HTTP或HTTPS请求,‌重新开始整个过程。

相关文章:

2024前端面试(内容持续更新)

Vue篇 data为什么是个函数&#xff1f; 在‌Vue中&#xff0c;‌data必须是一个‌函数&#xff0c;这是因为当data是函数时&#xff0c;每个组件实例化时都会调用该函数&#xff0c;返回一个新的数据对象&#xff0c;从而保证每个组件实例拥有独立的数据&#xff0c;避免数据冲…...

接口基础知识5:详解request headers(一篇讲完常见字段)

课程大纲 一、请求头的定义 HTTP请求头部&#xff08;HTTP Request Headers&#xff09;&#xff1a;HTTP协议中的一部分&#xff0c;用于在客户端和服务器之间传递附加信息。这些头部字段提供了关于请求、客户端环境、或请求的上下文的信息。 请求头是键值对的形式&#xff…...

mac的node使用

查看当前Node和npm版本 node -v npm -v安装"n"版本管理工具 sudo npm install -g n 更新node版本 sudo n stable // 稳定版本 sudo n lts // 最新稳定版本 sudo n latest // 最新版本 sudo n xx.xx // 更新到指定版本查看node版本安装集合 n ls切换对应node版…...

HTML - 简易版打字练习

1. 赛博朋克风格的视觉设计 颜色与渐变&#xff1a;通过linear-gradient设置了背景的颜色渐变&#xff0c;使用高饱和度的霓虹色彩&#xff08;如橙色、绿色和蓝色&#xff09;来营造赛博朋克的视觉效果。这种配色方案是赛博朋克风格的典型元素。 立体感和阴影&#xff1a;使用…...

【生成式人工智能-四-chatgpt的训练过程-pretrain预训练自督导式学习督导式学习】

大模型是怎么被训练出来的具有人类智慧的 阶段一训练-自我学习-具备知识训练资料self-supervised learning&#xff08;自督导式学习&#xff09; 阶段二-怎么让模型具备人的智慧supervised learning 督导式学习预训练pretrain为什么要用预训练的模型&#xff1f;Adapter逆向工…...

期权价格的奥秘:深入理解影响因素

在金融市场中&#xff0c;期权作为一种衍生工具&#xff0c;为投资者提供了风险管理和资产增值的多种可能性。期权价格的波动往往令人着迷&#xff0c;但其背后的定价机制却充满了复杂性。本文将带您探索期权价格变化的奥秘&#xff0c;并尝试以浅显易懂的方式&#xff0c;解析…...

STM32-USART时序与寄存器状态分析

一、时序分析 在UART&#xff08;通用异步收发传输&#xff09;通信中&#xff0c;信号线上的状态分为两种&#xff1a;逻辑1&#xff08;高电平&#xff09;和逻辑0&#xff08;低电平&#xff09;。在空闲状态下&#xff0c;数据线应保持逻辑高电平。UART协议中的各个信号位具…...

从零安装pytorch并在pycharm中使用

背景介绍 目前主流使用的工具有Facebook搞的pythorch和谷歌开发的tensorflow两种&#xff0c;二者在实现理念上有一定区别&#xff0c;pytorch和人的思维模式与变成习惯更像&#xff0c;而tensorflow则是先构建整体结构&#xff0c;然后整体运行&#xff0c;开发调试过程较为繁…...

开源AI工具FastGPT和RagFlow对比

FastGPT和RagFlow都是基于大型语言模型&#xff08;LLM&#xff09;的先进AI系统&#xff0c;它们在多个方面有着各自的特点和优势。 以下是对两者性能的详细对比&#xff1a; 一、系统架构与功能 FastGPT&#xff1a; 数据收集&#xff1a;通过从互联网上收集大量的文本数…...

第N2周:NLP中的数据集构建

对于初学者&#xff0c;NLP中最烦人的问题之一就数据集的构建问题&#xff0c;处理不好就会引起shape问题&#xff08;各种由于shape错乱导致的问题&#xff09;。这里给出一个模版&#xff0c;大家可根据这个模版来构建。 torch.utils.data是PyTorch中用于数据加载和预处理的…...

AI助力浮雕创作!万物皆可浮雕?Stable Diffusion AI绘画【浮雕艺术】之文生浮雕!

前言 对于浮雕艺术&#xff0c;其实并不了解。但有幸能和“细辛”前辈结识&#xff0c;对浮雕有了简单的了解&#xff0c;浮雕图案的传统方式是先由画师画出图&#xff0c;然后由雕刻师雕刻。画师画图归为浮雕的设计阶段&#xff0c;画师会绘制出浮雕的设计图&#xff0c;‌这为…...

你觉得大模型时代该出现什么?

大模型的概念都火了两年了&#xff0c;之前各种媒体吹嘘大模型的出现是类似“蒸汽机时代”、“iPhone时刻”等等。那为什么我们期待的结果都没出现呢&#xff1f;咱们先一起回顾下历史。 1、蒸汽机时代 1.1、蒸汽机历史 许多人都在讨论大模型时代好像只是概念在火&#xff0…...

JS【详解】事件委托

事件委托的简介 事件委托&#xff08;Event Delegation&#xff09;是 JS 处理事件的一种技术&#xff1a;不直接在目标元素上设置事件监听器&#xff0c;而是在其父元素或祖先元素上设置监听器&#xff0c;然后利用事件冒泡机制来捕获和处理事件。 事件委托的好处 减少内存占用…...

谈对象系列:C++类和对象

文章目录 一、类的定义1.1类定义的格式类的两种定义方法结构体&#xff1a; 1.2访问限定符1.3类域 二、实例化2.1变量的声明和定义2.2类的大小计算空类的大小&#xff08;面试&#xff09;&#xff1a; 三、this指针小考题 一、类的定义 1.1类定义的格式 使用class关键字&…...

设计模式20-备忘录模式

设计模式20-备忘录 动机定义与结构定义结构 C代码推导优缺点应用场景总结备忘录模式和序列化备忘录模式1. **动机**2. **实现方式**3. **应用场景**4. **优点**5. **缺点** 序列化1. **动机**2. **实现方式**3. **应用场景**4. **优点**5. **缺点** 对比总结 动机 在软件构建过…...

绘制echarts-liquidfill水球图

文章目录 一、效果图二、步骤1.安装插件2.引入2.主要代码2.素材图片 总结 一、效果图 二、步骤 1.安装插件 npm install echarts npm install echarts-liquidfillecharts5的版本与echarts-liquidfill3兼容&#xff0c;echarts4的版本与echarts-liquidfill2兼容,安装的时候需要…...

应急响应:D盾的简单使用.

什么是应急响应. 一个组织为了 应对 各种网络安全 意外事件 的发生 所做的准备 以及在 事件发生后 所采取的措施 。说白了就是别人攻击你了&#xff0c;你怎么把这个攻击还原&#xff0c;看看别人是怎么攻击的&#xff0c;然后你如何去处理&#xff0c;这就是应急响应。 D盾功…...

c语言第14天笔记

通过指针引用数组 数组元素的指针 数组指针&#xff1a;数组中的第一个元素的地址&#xff0c;也就是数组的首地址。 指针数组&#xff1a;用来存放数组元素地址的数组&#xff0c;称之为指针数组。 注意&#xff1a;虽然我们定义了一个指针变量接收了数组地址&#xff0c;但…...

服装行业QMS中的来料检验:常见问题解析与解决策略

在服装行业的来料检验过程中&#xff0c;常会遇到一系列问题&#xff0c;这些问题可能影响到原材料的质量&#xff0c;进而影响最终产品的品质。以下将详细介绍来料检验的常见问题及相应的解决方法&#xff1a; 一、常见问题 外观瑕疵 问题描述&#xff1a;原材料表面存在污渍…...

健身动作AI识别,仰卧起坐计数(含UI界面)

用Python和Mediapipe打造&#xff0c;让你的运动效果一目了然&#xff01; 【技术揭秘】 利用Mediapipe的人体姿态估计&#xff0c;实时捕捉关键点&#xff0c;精确识别动作。 每一帧的关键点坐标和角度都被详细记录&#xff0c;为动作分析提供数据支持。 支持自定义动作训练&a…...

国防科技大学计算机基础课程笔记02信息编码

1.机内码和国标码 国标码就是我们非常熟悉的这个GB2312,但是因为都是16进制&#xff0c;因此这个了16进制的数据既可以翻译成为这个机器码&#xff0c;也可以翻译成为这个国标码&#xff0c;所以这个时候很容易会出现这个歧义的情况&#xff1b; 因此&#xff0c;我们的这个国…...

HTML 语义化

目录 HTML 语义化HTML5 新特性HTML 语义化的好处语义化标签的使用场景最佳实践 HTML 语义化 HTML5 新特性 标准答案&#xff1a; 语义化标签&#xff1a; <header>&#xff1a;页头<nav>&#xff1a;导航<main>&#xff1a;主要内容<article>&#x…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例

使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件&#xff0c;常用于在两个集合之间进行数据转移&#xff0c;如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model&#xff1a;绑定右侧列表的值&…...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练

前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1)&#xff1a;从基础到实战的深度解析-CSDN博客&#xff0c;但实际面试中&#xff0c;企业更关注候选人对复杂场景的应对能力&#xff08;如多设备并发扫描、低功耗与高发现率的平衡&#xff09;和前沿技术的…...

WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)

一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解&#xff0c;适合用作学习或写简历项目背景说明。 &#x1f9e0; 一、概念简介&#xff1a;Solidity 合约开发 Solidity 是一种专门为 以太坊&#xff08;Ethereum&#xff09;平台编写智能合约的高级编…...

关于 WASM:1. WASM 基础原理

一、WASM 简介 1.1 WebAssembly 是什么&#xff1f; WebAssembly&#xff08;WASM&#xff09; 是一种能在现代浏览器中高效运行的二进制指令格式&#xff0c;它不是传统的编程语言&#xff0c;而是一种 低级字节码格式&#xff0c;可由高级语言&#xff08;如 C、C、Rust&am…...

JVM虚拟机:内存结构、垃圾回收、性能优化

1、JVM虚拟机的简介 Java 虚拟机(Java Virtual Machine 简称:JVM)是运行所有 Java 程序的抽象计算机,是 Java 语言的运行环境,实现了 Java 程序的跨平台特性。JVM 屏蔽了与具体操作系统平台相关的信息,使得 Java 程序只需生成在 JVM 上运行的目标代码(字节码),就可以…...

GitHub 趋势日报 (2025年06月06日)

&#x1f4ca; 由 TrendForge 系统生成 | &#x1f310; https://trendforge.devlive.org/ &#x1f310; 本日报中的项目描述已自动翻译为中文 &#x1f4c8; 今日获星趋势图 今日获星趋势图 590 cognee 551 onlook 399 project-based-learning 348 build-your-own-x 320 ne…...

在鸿蒙HarmonyOS 5中使用DevEco Studio实现企业微信功能

1. 开发环境准备 ​​安装DevEco Studio 3.1​​&#xff1a; 从华为开发者官网下载最新版DevEco Studio安装HarmonyOS 5.0 SDK ​​项目配置​​&#xff1a; // module.json5 {"module": {"requestPermissions": [{"name": "ohos.permis…...

关于uniapp展示PDF的解决方案

在 UniApp 的 H5 环境中使用 pdf-vue3 组件可以实现完整的 PDF 预览功能。以下是详细实现步骤和注意事项&#xff1a; 一、安装依赖 安装 pdf-vue3 和 PDF.js 核心库&#xff1a; npm install pdf-vue3 pdfjs-dist二、基本使用示例 <template><view class"con…...