剖析 Vue:最适合小白入手的前端框架
.markdown-body { line-height: 1.75; font-weight: 400; font-size: 15px; overflow-x: hidden; color: rgba(43, 43, 43, 1); font-family: -apple-system, system-ui, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif; background-image: linear-gradient(90deg, rgba(159, 219, 252, 0.15) 3%, rgba(0, 0, 0, 0) 0), linear-gradient(1turn, rgba(159, 219, 252, 0.15) 3%, rgba(0, 0, 0, 0) 0); background-size: 20px 20px; background-position: center }
.markdown-body h1, .markdown-body h2, .markdown-body h3, .markdown-body h4, .markdown-body h5, .markdown-body h6 { padding: 30px 0; margin-top: 35px; margin-bottom: 10px; color: rgba(77, 208, 225, 1) }
.markdown-body h1 { font-size: 30px; text-align: center; position: relative; width: max-content; margin: 0 auto }
.markdown-body h1:before { position: absolute; content: ""; z-index: -1; top: -20px; height: 100%; width: 100px; left: 0; right: 0; margin: 0 auto; background: url("") center / 64px 64px no-repeat; opacity: 0.84 }
.markdown-body h1:after { position: absolute; content: ""; width: 150%; left: -25%; height: 50%; bottom: 12px; border-radius: 50%; background: linear-gradient(rgba(0, 0, 0, 0) 80%, rgba(77, 208, 225, 0.8)); opacity: 0.6; animation: 6s linear infinite h1animate }
@keyframes h1Animate { 0% { background-position: right bottom } 50% { background-position: right } 100% { background-position: right bottom } }
.markdown-body h2 { display: block; border-bottom: 4px solid rgba(77, 208, 225, 1); position: relative; font-size: 24px; padding: 12px 32px; margin: 30px 0 }
.markdown-body h2:before { width: 24px; height: 24px; left: 0; top: 0; margin: auto; background-size: 24px 24px; background-image: url("") }
.markdown-body h2:after, .markdown-body h2:before { content: ""; display: block; position: absolute; bottom: 0 }
.markdown-body h2:after { right: 0; width: 400px; height: 10px; border-top-right-radius: 24px; background: linear-gradient(90deg, rgba(255, 255, 255, 1), rgba(77, 208, 225, 1)); max-width: 50vw }
.markdown-body h3 { margin: 30px 0; font-size: 18px; position: relative; padding: 4px 32px; width: max-content }
.markdown-body h3:before { border-bottom: 2px solid rgba(77, 208, 225, 1); width: 100%; content: ""; display: block; height: 28px; position: absolute; left: 0; top: 0; bottom: -2px; margin: auto; background-size: 28px 28px; background-image: url(""); background-repeat: no-repeat; animation: 2s infinite alternate h3animationbefore }
@keyframes h3AnimationBefore { 0% { width: 28px } 25% { width: 100% } 50% { width: 100% } 100% { width: 100% } }
.markdown-body h3:after { content: ""; display: block; width: 28px; height: 28px; position: absolute; border: 2px solid rgba(77, 208, 225, 1); border-radius: 50%; right: -15px; top: 0; bottom: 0; margin: auto; background-size: 28px 28px; background-image: url(""); animation: 2s infinite alternate h3animationafter }
@keyframes h3AnimationAfter { 0% { } 10% { } 50% { transform: rotate(-1turn) } 100% { transform: rotate(-1turn) } }
.markdown-body h4 { font-size: 16px }
.markdown-body h5 { font-size: 15px }
.markdown-body h6 { margin-top: 5px }
.markdown-body p { line-height: inherit; margin: 22px 0; letter-spacing: 2px; font-size: 14px; word-spacing: 2px }
.markdown-body img { max-width: 80%; border-radius: 6px; display: block; margin: 20px auto !important; object-fit: contain; box-shadow: 0 0 16px rgba(110, 110, 110, 0.45) }
.markdown-body figcaption { display: block; font-size: 13px; color: rgba(43, 43, 43, 1) }
.markdown-body figcaption:before { content: ""; background-image: url(""); display: inline-block; width: 18px; height: 18px; background-size: 18px; background-repeat: no-repeat; background-position: center; margin-right: 5px; margin-bottom: -5px }
.markdown-body hr { border-top: 1px solid rgba(77, 208, 225, 1); border-right: none; border-bottom: none; border-left: none; margin-top: 32px; margin-bottom: 32px }
.markdown-body del { color: rgba(77, 208, 225, 1) }
.markdown-body code { border-radius: 2px; overflow-x: auto; background-color: rgba(77, 208, 225, 0.08); color: rgba(38, 198, 218, 1); padding: 0.195em 0.4em }
.markdown-body pre { font-family: Menlo, Monaco, Consolas, Courier New, monospace; overflow: auto; position: relative; line-height: 1.75; box-shadow: 0 0 8px rgba(110, 110, 110, 0.45); border-radius: 4px; margin: 16px }
.markdown-body pre:before { content: ""; display: block; height: 30px; width: 100%; margin-bottom: -7px; background: url("") 10px 10px / 40px no-repeat }
.markdown-body pre>code { font-size: 12px; padding: 15px 12px; margin: 0; word-break: normal; display: block; overflow-x: auto; color: rgba(51, 51, 51, 1); background: rgba(248, 248, 248, 1) }
.markdown-body a { color: rgba(77, 208, 225, 1); border-bottom: 1px solid rgba(77, 208, 225, 1); font-weight: 400; text-decoration: none; margin: 0 4px }
.markdown-body a:active, .markdown-body a:hover { background-color: rgba(77, 208, 225, 0.1) }
.markdown-body strong { color: rgba(38, 198, 218, 1) }
.markdown-body strong:before { content: "「" }
.markdown-body strong:after { content: "」" }
.markdown-body em { font-style: normal; color: rgba(77, 208, 225, 1); font-weight: 700 }
.markdown-body table { display: inline-block !important; font-size: 12px; width: auto; max-width: 100%; overflow: auto; border: 1px solid rgba(246, 246, 246, 1) }
.markdown-body thead { background: rgba(246, 246, 246, 1); color: rgba(0, 0, 0, 1); text-align: left }
.markdown-body tr:nth-child(2n) { background-color: rgba(77, 208, 225, 0.05) }
.markdown-body td, .markdown-body th { padding: 12px 7px; line-height: 24px }
.markdown-body td { min-width: 120px }
.markdown-body blockquote { margin: 2em 0; padding: 24px 32px; border-left: 4px solid rgba(38, 198, 218, 1); background: rgba(77, 208, 225, 0.15); position: relative }
.markdown-body blockquote:before { content: "❝"; top: 8px; left: 8px; color: rgba(77, 208, 225, 1); font-size: 30px; line-height: 1; font-weight: 700; position: absolute; opacity: 0.7 }
.markdown-body blockquote:after { content: "❞"; font-size: 30px; position: absolute; right: 8px; bottom: 0; color: rgba(77, 208, 225, 1); opacity: 0.7 }
.markdown-body blockquote p { color: rgba(89, 89, 89, 1); line-height: 2 }
.markdown-body ol, .markdown-body ul { color: rgba(89, 89, 89, 1); padding-left: 28px }
.markdown-body ol li, .markdown-body ul li { margin-bottom: 0; list-style: inherit }
.markdown-body ol li .task-list-item, .markdown-body ul li .task-list-item { list-style: none }
.markdown-body ol li .task-list-item ol, .markdown-body ol li .task-list-item ul, .markdown-body ul li .task-list-item ol, .markdown-body ul li .task-list-item ul { margin-top: 0 }
.markdown-body ol ol, .markdown-body ol ul, .markdown-body ul ol, .markdown-body ul ul { margin-top: 3px }
.markdown-body ol li { padding-left: 6px }
@media (max-width: 720px) { .markdown-body h1 { font-size: 24px } .markdown-body h2 { font-size: 20px } .markdown-body h3 { font-size: 18px } }.markdown-body pre, .markdown-body pre>code.hljs { background: rgba(30, 30, 30, 1); color: rgba(220, 220, 220, 1) }
.hljs-keyword, .hljs-link, .hljs-literal, .hljs-name, .hljs-symbol { color: rgba(86, 156, 214, 1) }
.hljs-link { text-decoration: underline }
.hljs-built_in, .hljs-type { color: rgba(78, 201, 176, 1) }
.hljs-class, .hljs-number { color: rgba(184, 215, 163, 1) }
.hljs-meta-string, .hljs-string { color: rgba(214, 157, 133, 1) }
.hljs-regexp, .hljs-template-tag { color: rgba(154, 83, 52, 1) }
.hljs-formula, .hljs-function, .hljs-params, .hljs-subst, .hljs-title { color: rgba(220, 220, 220, 1) }
.hljs-comment, .hljs-quote { color: rgba(87, 166, 74, 1); font-style: italic }
.hljs-doctag { color: rgba(96, 139, 78, 1) }
.hljs-meta, .hljs-meta-keyword, .hljs-tag { color: rgba(155, 155, 155, 1) }
.hljs-template-variable, .hljs-variable { color: rgba(189, 99, 197, 1) }
.hljs-attr, .hljs-attribute, .hljs-builtin-name { color: rgba(156, 220, 254, 1) }
.hljs-section { color: rgba(255, 215, 0, 1) }
.hljs-emphasis { font-style: italic }
.hljs-strong { font-weight: 700 }
.hljs-bullet, .hljs-selector-attr, .hljs-selector-class, .hljs-selector-id, .hljs-selector-pseudo, .hljs-selector-tag { color: rgba(215, 186, 125, 1) }
.hljs-addition { background-color: rgba(20, 66, 18, 1) }
.hljs-addition, .hljs-deletion { display: inline-block; width: 100% }
.hljs-deletion { background-color: rgba(102, 0, 0, 1) }
在前端开发领域,Vue.js 凭借其独特的魅力与卓越的性能,成为众多开发者的心头好。尤其对于初涉前端开发的小白而言,Vue 以其简单易学、灵活高效的特性,堪称入门的绝佳选择。接下来,让我们全方位深入剖析 Vue 的技术精髓。
一、Vue 的使用基础
(一)快速上手
Vue 的上手极为便捷,只需引入 Vue.js 库,即可在 HTML 页面中轻松创建一个 Vue 实例。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Vue Quick Start</title>
<script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>
<body>
<div id="app">
<p>{{ message }}</p>
</div>
<script>
const { createApp } = Vue;
const app = createApp({
data() {
return {
message: 'Hello, Vue!'
};
}
});
app.mount('#app');
</script>
</body>
</html>
上述代码通过createApp创建了一个 Vue 应用实例,并将其挂载到id为app的 DOM 元素上。在模板中,使用{{ message }}语法实现了数据的插值显示。
(二)模板语法
Vue 的模板语法简洁直观,它允许开发者在 HTML 中嵌入 JavaScript 表达式。除了基本的数据插值,还支持指令,例如v-if用于条件渲染,v-for用于列表渲染。
<template>
<div>
<p v-if="isShow">这是一个条件显示的段落</p>
<ul>
<li v-for="(item, index) in list" :key="index">{{ item }}</li>
</ul>
</div>
</template>
<script>
import { ref } from 'vue';
export default {
setup() {
const isShow = ref(true);
const list = ref(['Apple', 'Banana', 'Cherry']);
return {
isShow,
list
};
}
};
</script>
在这个例子中,v-if根据isShow的值决定是否渲染
标签,v-for则遍历list数组并渲染出一个列表。
二、特色亮点
(一)轻量级与高性能
Vue.js 本身体积小巧,在保证功能强大的同时,尽可能减少了对页面加载速度的影响。其高效的虚拟 DOM diff 算法,能够精准地计算出实际需要更新的 DOM 部分,从而减少不必要的 DOM 操作,极大地提升了渲染性能。
(二)组件化开发
Vue 的组件化机制让开发者可以将页面拆分成一个个独立的、可复用的组件,每个组件都有自己的逻辑和样式。这不仅提高了代码的复用性,还使得项目的维护和拓展变得更加轻松。
// 父组件
<template>
<div>
<MyComponent :data="parentData" />
</div>
</template>
<script>
import MyComponent from './MyComponent.vue';
import { ref } from 'vue';
export default {
components: {
MyComponent
},
setup() {
const parentData = ref('传递给子组件的数据');
return {
parentData
};
}
};
</script>
// 子组件 MyComponent.vue
<template>
<div>{{ data }}</div>
</template>
<script>
export default {
props: ['data']
};
</script>
在上述代码中,父组件通过props向子组件传递数据,实现了组件间的通信与数据共享。
三、实现原理
(一)响应式系统
Vue 3 抛弃了 Vue 2 基于 Object.defineProperty 的响应式实现,采用 ES6 Proxy。在 Vue 2 中,Object.defineProperty 需逐个劫持对象属性,面对复杂对象时,性能受限且无法监听属性的新增与删除。而 ES6 Proxy 可直接代理整个对象,全面拦截对象的各种操作。
// 简单示例,展示Vue 3响应式原理
import { reactive } from 'vue';
const state = reactive({
count: 0
});
// 访问和修改响应式数据
console.log(state.count); // 输出: 0
state.count++;
console.log(state.count); // 输出: 1
在 Vue 源码中,reactive函数定义于@vue/reactivity包内。
// 简化的reactive实现
function reactive(target) {
return new Proxy(target, {
get(target, key) {
// 依赖收集
track(target, key);
return target[key];
},
set(target, key, value) {
const oldValue = target[key];
target[key] = value;
// 触发更新
trigger(target, key, oldValue, value);
return true;
}
});
}
Proxy的get方法负责依赖收集,set方法用于触发更新。不过,目前Proxy在兼容性上存在一定问题,在不支持 ES6 的老旧浏览器中,需引入polyfill解决。
(二)虚拟 DOM
Vue 3 重写了虚拟 DOM 的实现,大幅提升性能。虚拟 DOM 是真实 DOM 的 JavaScript 对象表示,通过对比新旧虚拟 DOM 的差异,仅更新实际变化部分,减少对真实 DOM 的操作。
与 React 的虚拟 DOM 相比,Vue 的虚拟 DOM 在模板编译阶段进行了更多优化,生成的渲染函数更高效。例如,Vue 能在编译时标记静态节点,更新时跳过这些节点的对比。
<template>
<div>
<p>{{ message }}</p>
</div>
</template>
<script>
import { ref } from 'vue';
export default {
setup() {
const message = ref('Hello, Vue 3!');
return {
message
};
}
};
</script>
在编译阶段,模板会被编译为渲染函数,生成虚拟 DOM。在 Vue 源码中,render函数生成虚拟 DOM 的过程如下:
// 简化的render函数生成虚拟DOM
function createVNode(type, props, children) {
return {
type,
props,
children
};
}
// 示例调用
const vnode = createVNode('div', null, 'Hello');
虽然 Vue 3 在虚拟 DOM 性能上有显著提升,但在处理超大规模列表且频繁更新的场景时,仍可能存在性能瓶颈。
而 Vue 3.4 版本在虚拟 DOM 的 Diff 算法上进一步优化,采用更高效的对比策略,提升了复杂数据结构下虚拟 DOM 的比对速度,减少不必要的 DOM 更新操作。
四、框架机制
(一)组件化机制
Vue 3 的组件化机制更加灵活强大。组件可通过defineComponent函数定义,支持多种数据传递和事件触发方式。与 Angular 的组件化相比,Vue 的组件定义简洁直观,学习成本低。在 Vue 中,父子组件间的数据传递和事件通信非常方便。
<template>
<div>
<ChildComponent :data="parentData" @child-event="handleChildEvent" />
</div>
</template>
<script>
import { defineComponent, ref } from 'vue';
import ChildComponent from './ChildComponent.vue';
export default defineComponent({
components: {
ChildComponent
},
setup() {
const parentData = ref('Data from parent');
const handleChildEvent = (data) => {
console.log('Received data from child:', data);
};
return {
parentData,
handleChildEvent
};
}
});
</script>
在子组件中:
<template>
<button @click="sendDataToParent">Send Data</button>
</template>
<script>
import { defineComponent, emit } from 'vue';
export default defineComponent({
props: ['data'],
setup(props, { emit }) {
const sendDataToParent = () => {
emit('child-event', props.data);
};
return {
sendDataToParent
};
}
});
</script>
这种组件化机制提升了代码的复用性与可维护性。但在大型项目中,组件间的依赖关系可能变得复杂,需要良好的架构设计和代码组织来管理。
Vue 3.4 在组件化方面新增了对动态组件的更优支持,组件切换时过渡效果更平滑,并且优化了组件懒加载的内部逻辑,加快了加载速度,减少首屏加载时间。
(二)生命周期
Vue 3 的生命周期钩子函数与 Vue 2 类似,但在 Composition API 中有了新的使用方式。例如,onMounted用于在组件挂载后执行代码。与 React 的生命周期函数相比,Vue 的生命周期函数更清晰易懂,在 Composition API 中的使用使逻辑复用更容易。
import { onMounted } from 'vue';
export default {
setup() {
onMounted(() => {
console.log('Component is mounted');
});
}
};
在 Vue 源码中,生命周期钩子的实现与组件的初始化和更新过程紧密相关。例如,mountComponent函数会在合适的时机调用onMounted钩子。
// 简化的mountComponent函数
function mountComponent(instance) {
// 挂载前逻辑
callHook(instance, 'beforeMount');
// 实际挂载操作
//...
callHook(instance, 'mounted');
}
不过,对于复杂业务逻辑,在多个生命周期钩子中拆分和组织代码时,可能导致代码可读性下降,需谨慎处理。Vue 3.4 对生命周期钩子的触发时机进行了更精准的优化,确保在不同渲染场景下,钩子函数都能按预期顺序和时机执行。
五、核心思想
(一)渐进式框架
Vue 的渐进式特性允许开发者根据项目需求逐步引入其功能。可以从简单的 DOM 操作开始,逐步扩展到复杂的单页面应用。与其他框架相比,这种特性使 Vue 非常适合初学者和小型项目的快速迭代。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Vue Progressive Example</title>
<script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>
<body>
<div id="app">
<button @click="count++">Increment</button>
<p>{{ count }}</p>
</div>
<script>
const { createApp } = Vue;
const app = createApp({
data() {
return {
count: 0
};
}
});
app.mount('#app');
</script>
</body>
</html>
这个简单示例展示了如何快速用 Vue 增强 HTML 页面的交互性,随着项目发展,可逐步引入组件化、路由等功能。但对于习惯大型框架一站式解决方案的开发者,渐进式引入方式可能需要时间适应。
(二)数据驱动
Vue 强调数据驱动的开发模式,通过将数据与视图绑定,数据变化时视图自动更新。这一思想贯穿 Vue 的设计,使开发者能专注于数据的逻辑处理,而非手动操作 DOM。
与传统直接操作 DOM 的开发方式相比,数据驱动的开发模式提高了开发效率和代码的可维护性。但在需要对 DOM 进行复杂动画操作等特殊场景下,可能需要结合其他技术实现。
在 Vue 3.4 中,通过优化数据劫持和依赖跟踪的底层机制,深化了数据驱动理念,使数据变化时的响应更迅速准确,提升了应用的数据流转效率。
六、未来发展方向
(一)性能优化持续升级
Vue 团队将继续优化框架性能,提升虚拟 DOM 的对比效率和组件的渲染速度。未来可能引入更多编译时优化技术,减少运行时开销。
例如,目前正在研究的基于块的渲染系统,有望大幅提升性能。通过将模板划分为多个独立的块,每个块可独立进行渲染和更新,避免不必要的整体渲染,提高渲染效率。
(二)生态系统拓展
Vue 的生态系统,如 Vue Router、Vuex 等,将不断完善和拓展。与其他前沿技术的集成,如 WebAssembly,可能成为未来的发展方向,以提供更强大的功能。
目前,Vue 与 WebAssembly 的集成处于探索阶段,未来有望实现更高效的计算和更卓越的性能表现,通过 WebAssembly 将复杂计算任务以接近原生的速度运行,提升应用整体性能。
(三)对新浏览器特性的支持
随着浏览器技术的发展,Vue 将积极支持新的浏览器特性,如原生 JavaScript 模块、CSS 变量等,提供更现代化的开发体验。
借助原生 JavaScript 模块,可实现更高效的代码拆分和按需加载,提升应用加载速度;利用 CSS 变量,可实现更灵活的样式管理和动态主题切换。
(四)更好的 TypeScript 支持
TypeScript 在前端开发中的地位日益重要,Vue 将持续加强对 TypeScript 的支持,提供更完善的类型定义和开发体验,帮助开发者编写更健壮的代码。
目前,Vue 对 TypeScript 虽有一定支持,但在类型推导和复杂类型的处理上还有提升空间。未来,Vue 有望在 TypeScript 支持方面实现重大突破,如提供更智能的类型推断,减少开发者手动编写类型声明的工作量,提高代码的可维护性和可读性。
Vue 凭借其简单易用、功能强大、灵活高效等诸多优势,当之无愧是最适合小白入手的前端框架。尽管目前还存在一些有待改进的地方,但随着 Vue 团队的持续努力和社区的大力支持,Vue 必将在前端开发领域持续发光发热,为开发者带来更多的惊喜与便利,推动前端技术不断迈向新的高度。
剖析 Vue:最适合小白入手的前端框架的更多相关文章
- React 还是 Vue: 你应该选择哪一个Web前端框架?
学还是要学的,用的多了,也就有更多的认识了,开发中遇到选择的时候也就简单起来了. 本文作者也做了总结: 如果你喜欢用(或希望能够用)模板搭建应用,请使用Vue 如果你喜欢简单和“能用就行”的东西 ...
- 基于Vue.js的uni-app前端框架结合.net core开发跨平台project
一.由来 最近由于业务需要要开发一套公益的APP项目,因此结合所给出的需求最终采用uni-app这种跨平台前端框架以及.netcore快速搭建我们的项目,并且能做到一套代码跨多个平台. 当然在前期技术 ...
- 一款简单而不失强大的前端框架——【Vue.js的详细入门教程①】
↓— Vue.js框架魅力 —↓ 前言 Vue.js 是一个构建数据驱动的 web 界面的渐进式框架.Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件.V ...
- uni-app开发一次,覆盖多端的前端框架
uni-app 是一个使用 Vue.js 开发跨平台应用的前端框架,开发者编写一套代码,可编译到iOS.Android.H5.小程序等多个平台. 一套代码,运行多个平台 uni-app实现了一套代码, ...
- 前端框架:react还是vue?
之前写了一篇前端框架的大汇总,主要介绍了当下主流的框架和其特性.最近除了bootstrap,就属react和vue最为热门,这篇就主要拿这两个框架来做一下详细对比. 究竟如何正确使用?作为小白的我们从 ...
- 【总结】前端框架:react还是vue?
之前写了一篇前端框架的大汇总,主要介绍了当下主流的框架和其特性.最近除了bootstrap,就属react和vue最为热门,这篇就主要拿这两个框架来做一下详细对比. 究竟如何正确使用?作为小白的我们从 ...
- 后端视角下的前端框架之Vue.js初探
背景 作为常年搞后端的自己来说,除了多年前学习的一点关于HTML的皮毛,对现在的前端技术栈可谓是一窍不通.但是因为最近在做的内部业务全链路监控系统,负责前端的同事做到一半去搞别的项目了,为了把项目落地 ...
- (转)2018几大主流的UI/JS框架——前端框架 [Vue.js(目前市场上的主流)]
https://blog.csdn.net/hu_belif/article/details/81258961 2016年开始应该是互联网飞速发展的几年,同时也是Web前端开发非常火爆的一年,Web ...
- Vue + Element UI 实现权限管理系统 前端篇(一):搭建开发环境
技术基础 开发之前,请先熟悉下面的4个文档 vue.js2.0中文, 优秀的JS框架 vue-router, vue.js 配套路由 vuex,vue.js 应用状态管理库 Element,饿了么提供 ...
- 纯小白入手 vue3.0 CLI - 2.1 - 组件 ( component )
vue3.0 CLI 真小白入手全教程系列:https://www.cnblogs.com/ndos/category/1295752.html 我的 github 地址 - vue3.0Study ...
随机推荐
- 2024数证杯决赛团体赛wp
2024数证杯决赛团体赛wp 容器密码:mW7@B!tRp*Xz46Y9#KFUV^J2&NqoHqTpLCE%8rvGW(AX#1k@YL3$M5!bWY*9HLFq7UZR6^T!XoVm ...
- HarmonyOS SDK让小红书鸿蒙用户尽享原生相机的拍摄之美
小红书是深受年轻人喜爱的生活社交类社区平台,越来越多的人在小红书上分享旅行.日常.心情.近日,不少使用鸿蒙原生版小红书的细心用户已经发现,直接使用小红书拍摄照片与自己使用原相机拍摄有一样清晰美观的呈现 ...
- vuex 踩坑记之unknown local mutation type
使用模块化定义vuex时,出现了这么个错误unknown local mutation type,检查好久发现单词并没有写错,代码如下: // 引入请求数据的方法 import { reqUsers ...
- mysql存储过程之循环遍历查询结果集
mysql存储过程之循环遍历查询结果集 -- 创建存储过程之前需判断该存储过程是否已存在,若存在则删除 DROP PROCEDURE IF EXISTS init_reportUrl; -- 创建存储 ...
- HTTP/1.1 优化
避免发送 HTTP 请求 对于一些具有重复性的 HTTP 请求,比如每次请求得到的数据都一样的,我们可以把这对「请求-响应」的数据都缓存在本地,通过缓存技术减少请求次数. 客户端会把第一次请求以及响应 ...
- 请求方法:GET 与 POST
根据 RFC 规范,GET 的语义是从服务器获取指定的资源,GET 请求的参数位置一般是写在 URL 中,URL 规定只能支持 ASCII,所以 GET 请求的参数只允许 ASCII 字符 ,而且浏览 ...
- Centos 安装 nload (流量监控)
QQ交流群:646559931.系统安装基本工具[root@localhost ~]# yum install -y gcc gcc-c++ make flex byacc libpcap ncurs ...
- linux 下给网卡添加ipv6、路由
route命令的使用举例如下: route // 显示路由信息. route add –host 192.168.1.110 dev eth0 // 给网卡eth0的路由表中加入新地址192 ...
- Draw.io:你可能不知道的「白嫖级」图表绘制神器
介绍 draw.io 是一个在 GitHub 上开源且拥有近十年发展历史的成熟项目,它是一款用于绘制 UML 图表的工具. 如果你曾经为流程图的绘制而流泪,又或是在夜里和UML大战到失眠, 不妨试试它 ...
- bug|初始化项目|sass-loader报错:TypeError: this.getResolve is not a function at Object.loader
Module build failed: TypeError: this.getResolve is not a function at Object.loader的解决 npm uninstall ...