广告
广告
广告
vue cli目前还没有自带这个功能,需要安装一个webpack的插件:插件安装yarn add compression-webpack-plugin更新:2020-12-17 千万不要安装最新的7.0版本,会报错,而且目前没有人提供解决方案,我这里提供两个版本,大家自行选择安装稍微新一些的yarn add compression-webpack-plugin@6.1.1旧的yarn add compression-webpack-plugin@4.0.0使用这两个版本不会出现报错,个人亲测配置安装完打开vue的配置文件vue.config.js,和package.json文件同级,没有...
无序列表 ul并不是所有的并列关系的数据都要使用到ul无序列表,ul他大多数出现在行文中间,也就是在ul的上部,我们一般会有文字说明,如列举一些选项啥的。所以,对于语义标签,我的态度是:‘“用对" 比“不用” 好,“不用" 比“用错”好。当然了,我觉得有理想的前端工程师还是应该去追求“用对”它们。所以,有时候用其他元素替换ul,反倒可以减少冗余的标签。(感觉我就是那种,为了所谓的语义而去大量使用的这种,这种习惯以后要改了)em强调倾斜和strong强调加粗em可能常常和strong标签概念混淆,而strong的大量使用,其实原因就是他不倾斜,文本加粗,在日常使用中,这种情况更多一些,即便...
Lay 是一个精心制作的侧边栏主题,提高了响应速度,优化了诸多地方历经时间打磨,更贴合需求预览特性基于Layui框架制作,模块化结构,异步加载js,加快页面响应响应式布局html5+css3+es5+es6基于Layui框架模块化结构异步js加载优秀的灯箱比较全面的代码高亮,精选四种高亮主题,支持常用的语言,还支持:shell、sass、scss、styles、less、c++、go、php、nginx、等语言。缩略文章无刷新加载,增加用户体验支持主题可视化配置侧边栏导航三种主题,可设置支持微信、支付宝二维码赞助符合国内的分享功能支持评论表情,更新了一些表情支持前台登录支持前台注册点赞效...
npm有nrm,我yarn怎么能没有呢全局安装npm install -g yrm --registry=https://registry.npm.taobao.org安装完毕,查看ls列表yrm ls如果提示你什么禁止运行脚本,且是win10 powerShell的话可以这样做:get-executionpolicy //他会返回Restricted set-executionpolicy remotesigned //旧win10可以用,新版不行 Set-ExecutionPolicy -Scope CurrentUser //最新win10使用该命令,输入完会让你输入...
npm换源应该是国内的基本操作了,但是每次用的时候,可能是百度啊,各种搜,总之搜到的结果,可能都很一般,不是你复制我,就是我复制你,东西缺胳膊少腿是常有的事。为此,npm有一个插件,可以快速的进行源的切换,而且方便,还能测速。首先我们需要安装,务必全局nrmnpm install -g nrm安装完毕后我们可以查看源列表nrm ls如果提示你什么禁止运行脚本,且是win10 powerShell的话可以这样做:get-executionpolicy //他会返回Restricted set-executionpolicy remotesigned //旧win10可以用,新版不行...
经常可以看到各种组件的文档,都是可交互,点开code按钮,还能查看对应的源码。那么我们如果要写一个这种的话,最省事的,应该就是在源代码的基础上,我们增加一个按钮,然后点开可以查看源码,反正就是尽量和书写vue项目一样。为了达到这个需要,我们有两个需求:怎么把vue文件作为代码文本显示代码文本怎么高亮解决这两点我们也能简单的搭建一个类似的可以交互的组件文档了。当然还有更高端的办法,就是自己写一个loader解析器,这个成本就很高了,一般人也不会这个,所以就不考虑了。怎么把vue文件作为代码文本显示webpack有一个插件: raw-loader他可以把text文本或者vue文件这些文件,拿...
moment作为一个时间插件,使用的地方是非常广泛的,但是我们使用moment的时候,需要注意下他的语言包。默认情况下,他的语言包是全加载的,也就是有多少个预设的语言包,就加载多少个。为此,我们需要对他进行优化优化前优化打开vue.config.js文件const webpack = require('webpack'); module.exports = { //... configureWebpack: { plugins: [ // Ignore all locale files of moment.js new webp...
关于图标的方案,现阶段也就三种:雪碧图字符图标svg雪碧图雪碧图就是将多个图标图片合并到一张图里面,前端通过控制图片的大小位置来进行显示。但是也有缺陷,就是图片的清晰度了,如果放大了,就会显的很模糊。字符图标字符图标是目前最成熟的一种方案,使用简单,并且是和字体一样的,放大依旧很清晰。但是他的缺点就是不支持多色图标,也就是一个字符图标,他无法同时显示多种颜色。svgsvg是最近开始兴起的,它是一种组件化封装的方式,将svg代码化,以达到控制的目的,而且相对于字符字体,svg本身有很多优势,比如动画,多色等等因为组件化了,所以我们可以按需引入,虽然字符图标也可以,但是那种是需要平台的支持,...
当我们请求一个api的时候,他返回的数据可能会有很多,这些数据可能需要分别拆分存放在data预设的变量中。这就导致我们可能要写好几个赋值操作this.xxx = xxx; this.xx = xxx; this.xx = xxx;我们可能会重复很多次上面这种操作,是不是有点麻烦。为此,我们可以利用Object.assign来达到我们的偷懒效果Object.assign(this,{xx:xxx},{xxx:xxx});使用这种方式,我们的vue可以检测到动态改变的值,也就是说watch监听是可以触发的。且效果和你写多个this.xxx=xxx是一样的。感觉这个方法妙啊,所以分享出来,当然...
最近有一个地方需要计算过期时间,然后返回天数,但是我用diff计算,得到的结果就是和后端算的相差一天。//后端返回的时间 const endTime = "2021-12-04"; //前端获取当前时间 const startTime = Date.now(); //或者new Date().getTime() //计算结果 const day = moment(endTime).diff(startTime,"days");得到的结果,永远是差一天的结果。比如今天是时间是:2020-12-08 10:46:00,转为时间戳为:160739556...
vue 的render语法让人崩溃,太过复杂,于是有了jsx,利用babel的插件,我们可以使用jsx语法。插件可以让我们在使用render的时候,语法更像template模板语法,用起来更容易上手。安装插件jsxnpm install @vue/babel-preset-jsx @vue/babel-helper-vue-jsx-merge-props安装完毕后我们需要进行配置配置插件找到babel.config.js文件,该文件和package文件同级,没有就自己手动创建一个。内容如下:module.exports = { presets: ['@vue/babel-p...
目前国内的图表库,除了百度的echarts就是蚂蚁的antv了,蚂蚁的图表样式更好看,相对来说,他的学习成本也很高,echarts已经是一个老牌图表了,有着比较完善的用法和社区。这里就了解下vue里面使用echarts需要注意的一些问题。使用EChartsECharts有提供一个vue版本的插件,也是由百度官方vue团队维护,有兴趣可以看看。vue-echarts我们这里就先不用这个插件了,用npm的方式安装npm install echarts安装完毕后我们就可以import引入<script> import echarts from "echarts&quo...
路由的鉴权只能处理大的方面,而更精细度的权限控制,就做不到了,如果我页面有一些按钮是需要有权限才能显示,那么,单路由鉴权根本无法做到。所以我们还需要更加精细化的权限控制。这里有两种权限的控制方式:权限组件权限指令权限组件权限组件可以理解为一个插槽组件,这个组件自身做一个权限判断,如果有权限我们就允许这个插槽内容展示。但是这么一个小小的功能其实也没必要做做一个传统组件,使用函数式组件他的性能会更高,因为用的地方很多,组件本身也没太多东西。既然是鉴权,我们自然需要一个用于判断是否有权限的函数,我们依旧可以使用上一章的check函数auth.js//后端返回权限 function getAut...
以前弄个一个路由鉴权,其原理就是判断用户是否已经登录,未登录就跳转至登录页。通过给meta设置一个元数据,然后判断这个页面是否有权限,如果访客没有权限,就跳转至登录页。这个用于一般情况完全是足够了,但是当你的网站权限分级的情况,就不太够用了,因为已经不能用单纯的是否已登录来判断,访客时候有权限浏览该页面。多级权限假设我们网站有四个等级:master(站长)、admin(管理员)、user(注册用户)、guest(游客)那么最先,我们给路由设置权限,设置哪些等级可以访问export default [ { path: "", component: () =&...
如果要实现这个功能,我们就需要去写一个layout布局的文件,然后通过一个动态的设置去响应这个变化。这个问题其实可以分两个方面去解析:布局文件怎么去做怎么去响应设置布局文件对于写一个布局文件,其实也不是很难,但是就是不要钻牛角尖,就好比,你可能会去想,一个侧边栏导航要怎么变成顶栏的横向导航?其实这种想法太过于钻牛角尖,为什么我们不能做两个导航呢?侧边栏sidebar我们使用一个导航,header里面我们也放一个导航,然后v-if判断不就好了。没必要想那么复杂,很多东西就是组件化,响应式数据进行显示。而且很多框架都预设了一些布局,我们可以利用那些布局,然后针对性的操作,大部分框架对这个些布...
最近遇到一个需求,希望在无内容的情况下能用--来表示无内容占位。所以,想来想去,用过滤器最好,然后既然是通用性,那么直接全局就行了。创建过滤器我们可以创建一个js文件,然后export导出,再到main文件里面导入并激活。创建一个名为globalFilters.js的过滤器文件,这个文件一般放在utils文件夹中,当然你也可以随意,只要能正确引入就行。// 全局过滤器 // 无内容占位符 const placeholder = (value) => { if (!value) return "--"; return value; }; export ...
直接把饿了么的返回顶部动画提取出来了,直接上代码//返回顶部函数 const cubic = (value) => Math.pow(value, 3); const easeInOutCubic = (value) => value < 0.5 ? cubic(value * 2) / 2 : 1 - cubic((1 - value) * 2) / 2; const el = document.documentElement; export const goScroll = function() { const beginTime = Date.n...
vuex作为一个共享的数据对象,用于不同组件的共用一个数据,并且动态响应数据变化,配合computed属性,可以对数据进行缓存。在vuex里面,在异步处理actions上,最终也还是要用到commit同步操作方法操作数据,并不是actions方法本身处理了数据,原因是因为需要有操作记录,方便在插件上查看。废话不多说,直接上底层原理。原理vuex其实就是一个重新封装的new Vue 对象,他的动态响应数据就是data属性,而commit这些方法,都只是回调而已。import Vue from "vue"; const Store = function(options ...
包含数字、字符、特殊字符,6-16位/(?=.*[a-z_])(?=.*\d)(?=.*[^a-z0-9])[\S]{6,16}$/提示信息:密码为6-16位,必须包含数字和字母和至少一个特殊字符!@-_=<>#*%+&^$
templatetemplate是html的扩展语法,数据绑定使用Mustache语法(双大括号)<span>{{message}}</span>所以template容易上手,入门极简,大量内置指令,拥有组件作用域css,但是因为简单,所以灵活性不高。jsxjsx是JavaScript的语法扩展,数据绑定使用单引号。<span>{message}</span>jsx相对于template,jsx更灵活,但是也不一定要完全抛弃template。jsx为什么灵活,原因就是他不是html模板,所以jsx中的标签,他可以是变量,我们改变这个变量,这...
最近评论