前言

写 vue 有很长一段时间了 , 在使用过程中会遇到各种场景的挑战 , 本文记录了我在使用 vue 中发现的一些好的实践,希望能够帮助到大家。

vue.js 使用技巧

覆盖 element-ui 样式

只覆盖某个组件内的 element-ui 样式,而不影响全局。

命名空间

由于 element-ui 的样式我们是在全局引入的,所以你想在某个页面里面覆盖它的样式就不能加 scoped,但你又想只覆盖这个页面的 element 样式,你就可在它的父级加一个 class,用命名空间来解决问题。

.article-page {/* 你的命名空间 */.el-tag {/* element-ui 元素*/margin-right: 0px;}
}
复制代码

样式穿透

vue 工程本来就比较庞大复杂,一个页面很可能会加载很多的组件,难免名字相同,除非你的项目有很严格的 命名空间管理 ,否则我更推荐使用深度作用选择器的方式来覆盖样式。

 <el-dialog><el-table style="margin-left:30px"></el-table></el-dialog><style scoped>.el-dialog >>> .el-table{margin-left:20px!important;/*这里的margin-left:20px;将会覆盖内联样式*/}</style>
复制代码

注意:如果你使用了一些预处理的东西,如 sass 你可以通过 /deep/ 来代替 >>> 实现想要的效果。

sass 和 js 之间变量共享

使用场景:动态换肤,需要将用户选择的主题传递给 css,初始化时 css 又需要将默认主题色传递给 js

js 将变量传递给 sass

可以通过 vue 内联标签的方式实现,或者使用 css var(),用 less 的话 modifyVars ,等等方案都能实现 jscss 的变量传递。

<div :style="{'background-color':color}" ></div>
复制代码

sass 将变量给 js

js 该怎么获取 sass 中的变量呢,通过 css-modules:export 来实现。

// var.scss
$theme: blue;:export {theme: $theme;
}
复制代码
// test.js
import variables from '@/styles/var.scss'
console.log(variables.theme) // blue
复制代码

调试 template 代码

vue.js 开发过程中,我们可以使用 DevTools 来完成代码调试工作,但有时候会遇到 template 模板渲染时 JavaScript 变量出错的问题。

我们可以使用 console.log 的方式来调试,推荐使用 vue 原型挂载的方式,毕竟不会只有一个组件需要调试。

// main.js
Vue.prototype.$log = window.console.log;// .vue
<div>{{$log(message)}}</div>
复制代码

当然我们也可以用 || 运算符,这样既能调试,也不会影响渲染。

<div>{{ $log(message) || message }}</div>
复制代码

attrs 和 listeners 二次封装组件

我们平时写业务的时候免不了需要对一些第三方组件进行二次封装,当我们去二次封装别人组件时,可能别人组件上有很多属性,我们不想再次重写一遍。

<template><div><el-button v-bind="$attrs">确定</el-button><div>
</template>// 父组件使用
<my-button type='primary' size='mini'/>
复制代码

另外,防止小伙伴们不熟悉 attrs 和 listeners,这里也做个简单介绍。

// 父组件
<home title="这是标题" @change="change" width="80" height="80" imgUrl="imgUrl"/>
复制代码
// 子组件
mounted() {console.log(this.$attrs) //{title: "这是标题", width: "80", height: "80", imgUrl: "imgUrl"}console.log(this.$listeners) //即可拿到 change 事件
},
复制代码

.sync 语法糖

当你有需要在子组件修改父组件值的时候这个方法很好用,它的实现机制和v-model是一样的。

热更新速度优化

热更新是我们每天打交道的东西,热更新的快慢,直接影响我们的开发效率。

首先,路由懒加载非常非常不适用于开发环境,会严重热更新速度。

区分开发环境

最早的方案是区分开发环境与生产环境,在路由文件夹下分别新建两个文件:

开发环境:

module.exports = file => require("@iews/" + file + ".vue").default;
复制代码

生成环境:

module.exports = file => () => import("@iews/" + file + ".vue");
复制代码

这样组件在开发环境下就是非懒加载,生产环境下就是懒加载的了。

dynamic-import-node

babeldynamic-import-node 是一种新的解决方案,其实思路都是一样的,只不过不需要开发者在需要建两份路由。

"env": {"development": {"plugins": ["dynamic-import-node"]}}
复制代码

最后,除了路由懒加载外,还应排查以下几点问题:

  1. 没有合理使用 souce map

  2. 开发环境不要压缩代码,提取 css babel polyfill

利用 object.freeze 提升性能

比方我们需要渲染一个非常大的数组对象,例如用户列表,对象列表,文章列表等等。

export default {data: () => ({users: {}}),async created() {const users = await axios.get("/api/users");this.users = users;}
};
复制代码

vue 会将 data 对象中的所有的属性加入到 vue 的响应式系统中,当这些属性的值发生改变时,视图将会产生 响应,若对象的体积比较大,会消耗很多浏览器解析时间。

所以我们可以通过减少数据的响应式转换来提供前端的性能。

export default {data: () => ({users: {}}),async created() {const users = await axios.get("/api/users");this.users = Object.freeze(users);}
};
复制代码

始终在 v-for 中使用 :key

加上 key 可以最大化的利用节点,减少性能消耗,至于原因,需要大家理解 diff 的过程,并且要对 virtual dom 有个了解。

<!-- 不好的做法-->
<div v-for='product in products'>  </div><!-- 好的做法 -->
<div v-for='product in products' :key='product.id'>
复制代码

注意:在工作中,发现很多人直接用index作为key,好像几乎没遇到过什么问题。确实,index作为key,在表现上确实几乎没有问题,但它主要有两点不足。

  • index 作为 key ,其实就等于不加 key

  • index 作为 key,只适用于不依赖子组件状态或临时 DOM 状态 (例如:表单输入值) 的列表渲染输出(这是 vue 官网的说明)

不要在同个元素上同时使用 v-if 和 v-for 指令

永远不要把 v-ifv-for 同时用在同一个元素上,v-forv-if 优先级高,所以嵌套使用的的话,每次 v-for 都会执行 v-if,造成不必要的计算,影响性能,尤其是当之需要渲染很小一部分的时候。

<ul><li v-for='product in products' :key='product.id' v-if='product.price < 50'>{{ product.name }}<>
</ul>
复制代码

为避免上述问题,可以使用过滤方法,方式如下:

<ul><li v-for='products in productsUnderPrice(50)' :key='product._id' >{{ product.name }}<>
</ul><script>export default {data () {return {products: []}},methods: {productsUnderPrice (price) {return this.products.filter(product => product.price < price)}}}
</script>复制代码

利用 require.context 简化 vux

require.contextwebpack 用来管理依赖的一个函数,可以利用它实现无限制的多级模块导入。

首先看我的 store 目录结构:

每一个文件都是一个模块,所以在 store/index.js 里面可以这样写 :

import Vue from 'vue'
import Vuex from 'vuex'Vue.use(Vuex)
const modulesFiles = require.context('./modules', true, /\.js$/)
const modules = modulesFiles.keys().reduce((modules, modulePath) => {// set './app.js' => 'app'const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1')const value = modulesFiles(modulePath)modules[moduleName] = value.defaultreturn modules
}, {})const store = new Vuex.Store({modules
})export default store
复制代码

使用 render 渲染组件

模板语法在大多数情况下很好,但有时候不是这样,所以这个时候渲染函数就会发挥作用。

// 模板语法
<template><div><div v-if="level === 1"> <slot></slot> </div><p v-else-if="level === 2"> <slot></slot> </p><h1 v-else-if="level === 3"> <slot></slot> </h1><h2 v-else-if="level === 4"> <slot></slot> </h2><strong v-else-if="level === 5"> <slot></slot> </stong><textarea v-else-if="level === 6"> <slot></slot> </textarea></div>
</template>// render 渲染函数
<script>export default {name:  hehe ,render(h) {const tag = [ div ,  p ,  strong ,  h1 ,  h2 ,  textarea ][this.level-1]return h(tag, this.$slots.default)},props: {level: {  type: Number,  required: true  } }}
</script>
复制代码

简单清晰很多!简单来说,这样代码精简很多。

注意:如果组件中有模板语法,那么 render 函数就会无效,并且如果使用了 render 函数,那么 vue 中自带的一些指令就不在生效了,包括 v-if , v-for 和 v-model ,需要我们自己实现。

render 适合复杂逻辑, template 适合逻辑简单;

vue 原理中,template 通过编译生成 AST,在由 AST 生成 render 函数,最后生成 虚拟DOM ,所以说 render 的性能会更高。

我们有必要了解 vue 中的一些基本概念,最后上一张图,这张图从宏观上展现了 vue 整体流程。

jsx 语法糖

复杂的 render 函数书写异常痛苦,好在官方提供了一个 Babel 插件,在 vuerender 函数中也可以直接使用 jsx 语法。

注意:如果你使用的是 vue-cli 3.x 创建的项目,那么不需要任何配置,直接就可以使用 jsx。

//模板语法<h1 v-if="level === 1"><slot></slot></h1><h2 v-else-if="level === 2"><slot></slot></h2><h3 v-else-if="level === 3"><slot></slot></h3>//jsx
const App = {render() {const tag = `h${this.level}`return <tag>{this.$slots.default}</tag>}
}
复制代码

函数式组件

如果我们所需的组件比较简单,没有管理任何状态,也没有生命周期方法,它只是接受一些 prop 的函数,在这样的场景下,我们可以使用函数式组件。

render

<script>
export default{functional: true, // 添加属性functional: true,表示该组件为函数式组件// Props 是可选的props: {// ...},// 为了弥补缺少的实例// 提供第二个参数作为上下文render: function (createElement, context) {// ...},
}
</script>
复制代码

functional

<template functional><div v-for="(item,index) in props.arr">{{item}}</div>
</template>
复制代码

context 描述

函数式组件是无状态的,也没有 this 上下文,没有 data 等属性,所以所有数据都是由 render 函数的第二个参数 context 获得的。

  • props:提供所有 prop 的对象

  • data:传递给组件的整个数据对象,作为 createElement 的第二个参数传入组件

  • children: VNode 子节点的数组

  • parent:对父组件的引用

  • slots: 一个函数,返回了包含所有插槽的对象

  • scopedSlots: (2.6.0+) 一个暴露传入的作用域插槽的对象。也以函数形式暴露普通插槽。

  • listeners: (2.3.0+) 一个包含了所有父组件为当前组件注册的事件监听器的对象。这是 data.on 的一个别名。

  • injections: (2.3.0+) 如果使用了 inject 选项,则该对象包含了应当被注入的属性。

动态切换组件

如果我们打算根据状态引用不同的组件,比如 tab 页,那么就会涉及到组件动态加载。

<component :is="currentTabComponent"></component>
复制代码

但是这样每次组件都会重新加载,会消耗大量性能,所以 <keep-alive> 就起到了作用

<keep-alive><component :is="currentTabComponent"></component>
</keep-alive>
复制代码

vue.js 常用的 API

vue.directive

vue 中,除了 v-modelv-ifv-show 等指令,还可以自己定义一些指令,来实现我们想要的功能。

使用场景:用于不可避免要操作 dom 元素时,把它放在自定义指令中。

全局指令

就是定义了一个指令,所有组件都可以使用。

参数1是指令的名字,参数2可以是函数也可以是对象。

// 函数
Vue.directive("save-color",function(el,binding,vnode){el.style["color"]= binding.value;  // 改变元素颜色console.log(el)   // 指令所在的dom元素console.log(binding)  // 存放绑定的信息console.log(vnode)    // 虚拟节点,指令绑定元素的节点
})// 对象
Vue.directive("save-color",{bind() {// 当指令绑定到 HTML 元素上时触发.**只调用一次**el.style["color"]= binding.value;},}
)// 使用自定义指令
<template>
<div v-save-color="color">{{message}}</div>
</template>
<script>export default{data(){return{color: red}}}
</script>
复制代码

组件指令

定义在某个组件内部,只在这个组件内部使用。

// 某组件
data(){return {// ... }
},
directives: {save-color: {// 指令的定义bind:function(el,binding){el.style["color"]= binding.value;}}
},
methods:{// ...}
复制代码

自定义指令生命周期

bind()   // 当指令绑定到 HTML 元素上时触发. **只调用一次**
inserted()  //当绑定了指令的这个HTML元素插入到父元素上时触发(在这里父元素是 `div#app`)
updated // 所在组件的`VNode`更新时调用
componentUpdated()  // 指令所在组件的 VNode 及其子 VNode 全部更新后调用。
unbind()  // 只调用一次,指令与元素解绑时调用.
复制代码

vue.mixin

在组件中,有一些常用的方法或是重复的 js 逻辑,如校验手机验证码,解析时间等,我们可以独立抽离出来,然后利用 mixins 实现混入。

混入:相当于扩展了组件的对象与方法,可以理解为形成了一个新的组件,能在不同组件里重用相同的代码。

注意:可以混入的不只有 methods ,还可以包含生命周期、data、computed 相当灵活。

局部混入

当组件使用 mixin 时,mixin 对象的所有信息,组件都可以访问到,就想在访问自己的对象一样。

// mixin.js file
export default {data () {msg: 'Hello World'},created: function () {console.log('Printing from the Mixin')},methods: {displayMessage: function () {console.log('Now printing from a mixin function')}}
}// -----------------------------------------// main.js file
import mixin from './mixin.js'
new Vue({mixins: [mixin],created: function () {console.log(this.$data)this.displayMessage()}
})
// => "Printing from the Mixin"
// => {msg: 'Hello World'}
// => "Now printing from a mixin function"复制代码

全局混入

全局的意思大家都懂,就是在所有组件都可以使用被 mixin 的对象。

Vue.mixin({//这里是要混入的内容
})
复制代码

注意:请谨慎使用全局混入的方法。毕竟只要使用了全局混入,所有实例都会共享混入的内容,不管你是否添加了 mixins。

mixins 特点

  • 方法和参数在各组件中不共享

  • mixin的数据对象和组件的数据发生冲突时以组件数据优先

  • 混入对象中如果有生命周期的钩子,那么混入对象和被混入对象的钩子都会被执行一遍,而且混入对象的钩子将在 实例(或组件)自身钩子之前先执行。因为同名钩子函数将混合为一个数组,因此都将被调用。

  • mixins 可以有多个,比如:mixins:[ mix1, mix2 , mix3],前提是定义了这些混入对象,不然就会报错。

vue.filter

能够对数据进行过滤处理,返回需要的结果,非常的方便和快捷。

全局过滤器

大部分的过滤器是要全局使用的,不会每每用到就在组件里面去写,抽成全局的会更好些。

srcb/filters.js

function formatMoney(value, fractionDigits = 2) {if (!value) {return "";}return (value / 100).toFixed(fractionDigits).toString();
}
export default function(instance) {instance.filter("formatMoney", formatMoney);
}
复制代码

src/main.js

import Vue from 'vue'
import App from './App'
import router from './router'
import initFilters from "@b/filters"Vue.config.productionTip = false
initFilters(Vue)new Vue({el: '#app',router,components: { App },template: '<App/>'
})
复制代码

template文件调用

<template><div class="demo"><h1>{{ msg }}</h1><h2>{{ price | formatMoney }}</h2><h2>{{ (price/100).toFixed(2) }}</h2></div>
</template><script>
export default {name: 'Demo',data () {return {msg: 'Welcome to Your Vue.js App',price: 1000}}
}
</script><style scoped></style>
复制代码

局部过滤器

本地过滤器存储在 Vue 组件中,作过 filters 属性中的函数。

export default {data() {return {}},filters: {// 首字母大写过滤器capitalize: function (value) {if (!value) return ''value = value.toString()return value.charAt(0).toUpperCase() + value.slice(1)}}
};
复制代码

过滤器的使用方法

  1. 双花括号插值(应用比较多)

{{ phone | privatePhone }}
复制代码
  1. v-bind 表达式 (2.1.0+ 开始支持)。

<div v-bind:data=" phone | privatephone "></div>
复制代码
  1. 使用多个过滤器

{{ phone | privatePhone | privatePhon2 }}
复制代码

过滤器之间需要用管道符 | 隔开,其执行顺序从左往右。

vue.extend

我们会用 vue.extend 封装一些全局插件,比如 toastdiolog 等。

平常我们都是使用 component 注册组件,然后在模板中使用,而 vue.extend 则是编程式的写法,并且显示与否需要手动的去做组件的挂载和销毁。

toast.js

import Vue from 'vue'const Toast = Vue.extend({template: '<div>{{ text }}</div>',data: function () {return {text: 'extend test'}}
})let instance
const toast = function(options) {options = options || {}instance = new Toast({data: options})instance.vm = instance.$mount()document.body.appendChild(instance.vm.$el)return instance.vm
}export default toast;
复制代码

main.js 引入 toast 组价并挂载在 vue 原型上

import Vue from 'vue'
import toast from './components/toast'
Vue.prototype.$toast = toast
复制代码

在项目中调用

this.$toast({ text: 'Hello Word' })
复制代码

vue.nextTick

定义:在下次 dom 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 dom

简单理解,就是数据更新完成,并且在 dom 中渲染后,自动执行该函数。

testClick:function(){let that=this;that.testMsg="修改后的值";that.$nextTick(function(){console.log(that.$refs.aa.innerText);  //输出:修改后的值});}
复制代码

其他

watch

常规用法

created(){this.getList()
},
watch: {inpVal(){this.getList()}
}复制代码

监听路由

watch:{$route(to,from){console.log(from.path);  //从哪来console.log(to.path);    //到哪去}
}复制代码

立即执行

watch:{$route:{handler(val,oldval){console.log(val);     //新路由信息console.log(oldval);  //老路由信息},// 深度观察监听deep: true}}
复制代码

route

路由传参

默认方案

// 路由定义
{path:  /describe/:id ,name:  Describe ,component: Describe
}
// 页面传参
this.$router.push({path: `/describe/${id}`,
})
// 页面获取
this.$route.params.id
复制代码

params

// 路由定义
{path:  /describe ,name:  Describe ,omponent: Describe
}
// 页面传参
this.$router.push({name:  Describe ,params: {id: id}
})
// 页面获取
this.$route.params.id
复制代码

query

// 路由定义
{path:  /describe ,name:  Describe ,component: Describe
}
// 页面传参
this.$router.push({path: /describe ,query: {id: id`}
)
// 页面获取
this.$route.query.id
复制代码

对比

params 参数不会拼接在路由后面,页面刷新参数会丢失 默认方案 和 query 参数拼接在后面,暴露了信息

路由跳转

this.$router.push():跳转到不同的url,但这个方法回向history栈添加一个记录,点击后退会返回到上一个页面
this.$router.replace():不会有记录
this.$router.go(n):n可为正数可为负数。正数返回上一个页面,类似 window.history.go(n)
复制代码

v-slot

默认插槽

// 父组件
<todo-list> <template v-slot:default>任意内容<p>我是默认插槽 </p></template>
</todo-list> // 子组件
<slot>我是默认值</slot>
复制代码

具名插槽

言简意骇,就是有名字的插槽。

// 父组件
<todo-list> <template v-slot:todo>任意内容<p>我是默认插槽</p></template>
</todo-list> //子组件
<slot name="todo">我是默认值</slot>
复制代码

作用域插槽

子组件内数据可以被父页面拿到,解决了数据只能从父页面传递给子组件。

// 父组件
<todo-list><template v-slot:todo="slotProps" >{{slotProps.user.firstName}}</template> 
</todo-list> 
//slotProps 可以随意命名
//slotProps 接取的是子组件标签slot上属性数据的集合所有v-bind:user="user"// 子组件
<slot name="todo" :user="user" :test="test">{{ user.lastName }}</slot> 
data() {return {user:{lastName:"Zhang",firstName:"yue"},test:[1,2,3,4]}},
// {{ user.lastName }}是默认数据  v-slot:todo 当父页面没有(="slotProps")


作者:海洋里的魔鬼鱼
链接:https://juejin.im/post/5ef03fa3f265da02d72812ba
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

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

相关文章

  1. 膜拜!Github上8.5K赞的Nginx从安装、配置、使用、实战文档

    前言拿到这本 《实战 Nginx》 有几天了,休假期间将感兴趣的几章阅读完毕。作者张宴是国内 Nginx 最早的技术传播者之一,产生的影响也最大,他的一系列 Nginx 实战的文章相信让很多 Nginx 用户受益良多。 尽管之前已经在他的网络文章或者 PPT 里看到过这本书里包含的一些内容,…...

    2024/5/6 21:10:25
  2. 04-Vue的基础语法(计算属性)

    1、什么是计算属性?我们知道,在模板中可以直接通过插值语法显示一些data中的数据。 但是在某些情况,我们可能需要对数据进行一些转化后再显示,或者需要将多个数据结合起来进行显示比如我们有firstName和lastName两个变量,我们需要显示完整的名称。但是如果多个地方都需要显…...

    2024/4/30 6:51:58
  3. visual gc 使用介绍

    ...

    2024/5/6 18:56:33
  4. leetcode 105. 从前序与中序遍历序列构造二叉树

    105. 从前序与中序遍历序列构造二叉树 根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7] 中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树:3/ \9 20/ \15 7首先要知道一个结论,前序/…...

    2024/5/7 0:55:46
  5. OpenGL之Assimp的使用(3)加载obj模型

    PS: 由于库太多,有的时候下载完又忘记了添加路径,这里我们可以自己配置一个opengl的环境建一个工程,右击项目,点击属性 设置三处位置,如下图:将assimp编译成的库添加到运行项目“Model”的“Debug”目录下运行,效果图如下:代码如下:...

    2024/4/25 8:47:39
  6. Android 碎片(fragment)

    Android 碎片(fragment) 效果如下:主要的代码:FragmentManager fm = getFragmentManager(); //创建待添加的布局FragmentTransaction ft = fm.beginTransaction(); //获取布局ft.replace(R.id.right_fragment, fragment); //开启布局使用ft.commit(); //提交布局View vi…...

    2024/5/7 5:14:36
  7. Win7环境下基于Anaconda安装tensorflow(CPU)的版本问题

    安装tensorflow前后花了三天时间, 踩过不少坑, 一度想放弃, 最后还是坚持到了胜利, 在此分享安装tensorflow的注意项. 一. 注意项: 1. 在Anaconda下安装, 千万不要另外去安装CUDA和cudnn 2. Numpy版本一定要与tensorflow版本匹配 3. 安装完tensorflow后不能直接使用Jupyter not…...

    2024/4/27 20:25:10
  8. JAVA三大特点之封装

    一、封装 封装:指隐藏对象的属性和实现细节,仅对外提供公共的访问方式,通过封装实现对属性的数据访问权限。使用private(私有的)关键字实现封装。 private修饰成员变量或者成员方法,被修饰的成员只能在本类中使用,如果想要在别的类中使用private修饰的成员,则必须调用se…...

    2024/4/30 17:10:42
  9. 【Mac】配置

    感觉Mac和linux差不太多iTerm2 + Oh My Zsh 打造舒适终端体验 首先字体需要改,不改得话没箭头。然后安装高亮插件的时候需要添加source ~/.oh-my-zsh/custom/plugins/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh。但这需要把下载的插件丢到这个路径里。当然也可以去…...

    2024/5/5 13:47:42
  10. ala的杂货店(开店第三天)

    Description 开张的第三天,dzl气势汹汹地带着m元钱来找ala,ala这次不打算为难他,拿出的n种物品中每种物品有一个对应的价格,dzl想知道花光m元钱可以购买的物品方案总数。今天可算是难住dzl了,想让你再次帮他解决这个问题。 Input 数据为单组 数据的第一行有两个整数,分别…...

    2024/4/21 20:08:18
  11. 项目开发日报表——第八天

    项目开发日报表——第八天项目名称 【苏嵌实训-嵌入式 linuxC 第 8 天】今日进度以及任务 嵌入式Linux C 多任务编程线程的资源保护机制(互斥锁、线程信号量、条件变量)、网络基础、网络编程本日任务完成情况 (详细说明本日任务是否按计划完成,开发的代码量) 编写代码实现…...

    2024/4/22 1:36:47
  12. O2O与B2B、B2C、C2C之间的区别

    O2O引用较多的一种解释是:O2O(Online To Offline)即线上到线下,其核心是把线上的消费者带到现实的商店中去,也就是让用户在线支付购买线下的商品和服务后,到线下去享受服务。首先,真正的O2O应立足于实体店本身,线上线下并重,线上线下应该是一个有机融合的整体,你中有…...

    2024/4/26 19:25:16
  13. js+php+mysql的简单学生管理系统,

    实现的效果如下图所示: 注册登录系统主页新增页面修改页面注册页面–register.html <!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, init…...

    2024/4/25 13:29:09
  14. css选择符

    css选择器 1)类型选择符(标签选择符) ​ 能选中左右同名标签 2) id选择器 ​ 用法: 用来划分网页外围结构 ​ 语法: <标签 id=“名称”> </标签> ​ #名称{ 属性:属性值} 3)类选择器(class选择器) ​ 语法:<标签 class=“名称”> </标签> ​ …...

    2024/4/9 10:58:03
  15. 京东E卡如何使用?

    一、京东E卡使用京东E卡可以在京东上购买自营商品,部分特殊商品除外,详细可见“购卡章程”,具体有效期请登录京东商城,在“我的京东”页面中—礼品卡—已绑定京东E卡,进入页面查看。购买产品使用的金额将从京东E卡中扣除。每笔订单最多可以使用200张京东E卡,由于浏览器的…...

    2024/4/22 1:15:05
  16. 08 Confluent_Kafka权威指南 第八章:跨集权数据镜像

    文章目录CHAPTER 8 Cross-Cluster Data Mirror 跨集权数据镜像Use Cases of Cross-Cluster Mirroring 跨集群镜像用例Multicluster Architectures 多集群架构Some Realities of Cross-Datacenter Communication 一些跨数据中心的实现Hub-and-Spokes Architecture 中心辐射架构A…...

    2024/4/9 12:30:29
  17. md文档输入上标和下标

    上标 格式:例如:输出结果是:n2。 下标 格式:例如:输出结果是:n1...

    2024/5/3 8:44:11
  18. 闲聊Elasticsearch(4) es集群健康检查和简单的索引操作

    文章目录1、检查集群的健康状况2、查看集群中有哪些索引3、简单的索引操作 这篇文章以kibana自带的例子来逐个讲解1、检查集群的健康状况 GET /_cat/health?v意思是这样的: epoll/timestamp:时间戳/时间。 cluster:集群名称。默认是elasticsearch status:集群状态。green–…...

    2024/4/21 21:19:45
  19. linux mmap详解

    mmap基础概念mmap是一种内存映射文件的方法,即将一个文件或者其它对象映射到进程的地址空间,实现文件磁盘地址和进程虚拟地址空间中一段虚拟地址的一一对映关系。实现这样的映射关系后,进程就可以采用指针的方式读写操作这一段内存,而系统会自动回写脏页面到对应的文件磁盘…...

    2024/4/23 17:57:39
  20. 多生产者-多消费者问题

    多生产者-多消费者问题 1.问题描述2.问题分析3.问题实现4.总结...

    2024/4/28 10:33:43

最新文章

  1. uboot图形界面配置

    文章目录 一、环境安装二、配置默认项2.图形界面 三、图形配置项的来源1.mainmenu主界面 一、环境安装 &#x1f4a6;uboot 或 Linux 内核可以通过输入“make menuconfig”来打开图形化配置界面&#xff0c;menuconfig是一套图形化的配置工具&#xff0c;需要 ncurses 库支持。…...

    2024/5/7 5:40:14
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/5/6 9:38:23
  3. 阿里云8核32G云服务器租用优惠价格表,包括腾讯云和京东云

    8核32G云服务器租用优惠价格表&#xff0c;云服务器吧yunfuwuqiba.com整理阿里云8核32G服务器、腾讯云8核32G和京东云8C32G云主机配置报价&#xff0c;腾讯云和京东云是轻量应用服务器&#xff0c;阿里云是云服务器ECS&#xff1a; 阿里云8核32G服务器 阿里云8核32G服务器价格…...

    2024/5/6 18:16:31
  4. C++ 【原型模式】

    简单介绍 原型模式是一种创建型设计模式 | 它使你能够复制已有对象&#xff0c;客户端不需要知道要复制的对象是哪个类的实例&#xff0c;只需通过原型工厂获取该对象的副本。 以后需要更改具体的类或添加新的原型类&#xff0c;客户端代码无需改变&#xff0c;只需修改原型工…...

    2024/5/5 8:37:55
  5. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/6 18:23:10
  6. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/6 18:40:38
  7. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/6 23:37:19
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/6 7:24:07
  9. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/7 0:32:52
  10. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/6 6:01:13
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/6 7:24:06
  12. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/7 1:54:46
  13. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/6 20:04:22
  14. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/7 0:32:51
  15. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/6 7:24:04
  16. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/6 7:24:04
  17. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/6 19:38:16
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/6 7:24:03
  19. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/7 0:32:49
  20. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/6 21:25:34
  21. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/6 7:24:02
  22. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/6 7:24:01
  23. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/7 0:32:47
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/6 16:50:57
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57