自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(25)
  • 收藏
  • 关注

原创 vue2转vue3方案

1. 方案一 vue-codemod1.1 文档1. [第三方文档](https://originjs.org/guide/tools/vue-codemod/)2. [官方仓库](https://github.com/vuejs/vue-codemod)1.2 来源来源为官方**vuejs**仓库,文档标明为实验阶段1.3 转换输出输出转换占比及文件可以在输出得文件日志中查看已转换文件和未转换文件1.4 更新周期github最近更新时间为2021-07-20npm最新发

2022-04-29 14:44:59 2810

原创 ts中得&和 |

1. 问题type Foo = { name: string age: string}type Bar = { name: string age: string gender: number}type a = keyof Foo | keyof Bartype b = keyof Foo & keyof Bar 今天在做**type-challenges**时,发现个自己之前忽略得东西,那就是**&**和**|**有什么不同2. 类型key中上面**

2022-03-30 10:25:46 1597 1

原创 vue3+vite+element-plus+husky+commitzen搭建项目

1.1 编辑器统一编码规范# http://editorconfig.orgroot = true[*] # 表示所有文件适用charset = utf-8 # 设置文件字符集为 utf-8indent_style = space # 缩进风格(tab | space)indent_size = 2 # 缩进大小end_of_line = lf # 控制换行类型(lf | cr | crlf)trim_trailing_whitespace = true # 去除行首的任意空白字符in

2022-02-21 20:57:58 879

原创 学习简单打包器的实现

学习地址本文代码地址1. 读取文件首先我们需要一个创建函数,并且读取我们指定文件的内容function createAssets(filePath) { const source = fs.readFileSync(filePath, { encoding: 'utf8', })}2. 生成语法树通过安装@babel/parser来将文件的内容解析成ast抽象语法树 const ast = parser.parse(source, { sourceType: 'mo

2022-01-24 19:50:18 647

原创 发布属于自己的npm包

1. 配置我们想要将我们的库或者包发布到**npm**上时,首先要将**package.json**进行配置,{ "name": "cli-demo", "bin": "./bin/index.js", "files": [ "bin", "package.json" ],}其中,**bin**就是就是我们整个包的入口位置,我们将运行文件的再放**bin**配置的位置,别人在使用的时候就会去执行我们的**bin/index.js**文件2. 入口文件#! /us

2021-12-12 18:11:27 376

原创 使用esbuild创建自己的cli-总结

1. ejs渲染我们可以通过**ejs**模板引擎来去渲染我们的ejs文件import ejx from 'ejs'const indexTemplate = fs.readFileSync( path.resolve(__direname, '../template/index.ejs') )const code = ejx.render(indexTemplate.toString(), { // ...})2. 绝对路径在**esbuild**中,没有**__d

2021-12-12 18:10:30 586

原创 Vite当中的scss配置踩坑

1. 场景今天想要给vite项目,添加全局的scss变量文件引用,这样我们在使用scss变量和函数的时候就不需要每个组件都取引用了2. 官方代码export default defineConfig({ css: { preprocessorOptions: { scss: { additionalData: `$injectedColor: orange;` } } }})3. 问题在如上面代码所示进行配置的时候,在vite进行

2021-12-06 19:25:32 3037

原创 Props中的default

1. 默认使用props: { obj: { type:Object, default:() => ({}) }, arr: { type:Array, default:() => ([]) }}2. 为什么需要通过函数的形式因为对象和数组都是属于我们的复杂类型,在进行访问指向的时候我们使用的是对象和数组的地址,而不像基础数据类型那。如果我们没有通过函数的形式去设置对象和数据类型的默认值,而是直接采用{}和[],如果多个使用该组件的地方因

2021-11-16 22:51:03 7390 1

原创 HMR(Hot Module Replacement)

就是我们俗称的热更新,在更新代码的时候只更新当前被修改的模块1.配置:module.exports = { target:"web", devServer: { hot: true, // 开启热更新 }}最好和target进行搭配,表示要打包成哪个平台2. 使用仅仅写了上面的配置的时候,我们模块的更新还是会刷新整个页面,而不能做到局部,因此我们需要在入口文件中进行判断配置下import ‘./a.js’if (module.hot) { module.hot.acc

2021-11-16 20:33:04 149

原创 Vite2的服务器原理

实现方式Vite2采用的是Connect进行连接和转发(Vite1使用的是Koa)转发步骤通过请求对应的文件,如果是JS后缀的文件那么直接进行返回,如果是不能被浏览器直接识别的文件,那么就通过Connect进行一层转发本地服务器去查找对应源代码,然后通过Vite的一些编译和转换,将不能直接识别的文件,转换为ES6的JS代码,然后将这个JS代码在发送给浏览器浏览器就完成更新和渲染页面...

2021-11-16 20:28:47 398

原创 ESModule

在比较新的版本的浏览器当中,我们可以通过下面的代码使用ES6中的import和export,本质就是把每一次导入导出当作一次浏览器的请求HTML:JS:import ‘./module.js’// 必须加上js后缀,此时还没有打包工具来帮我们配置查找后缀但是浏览器只能识别js,如果我们想要识别其他后缀的文件,例如ts,vue,less,scss等,就不能做到再者如果我们使用import的形式引入了第三方包中的一个A文件,如果该文件还依赖了其他的js文件的话,那么在浏览器请求加载A文件的时候,

2021-11-16 20:27:03 148

原创 vue实现图片的拖拽预览和放大缩小

html<div class="img-preview" v-else-if="fileType === 'image'" ref="imgPreviewRef"> <img :src="src" alt ref="imgRef" :style="`transform:scale(${imgScaleSize})`" /> </div> <div class="img-opt-btn"> <el-button c

2021-08-05 16:14:41 727

原创 将指定目录下的指定文件后缀的内容统一复制到指定文件

const fs = require('fs');const path = require('path')const ergodicDir = (Path, format, folderNameNew) => { fs.readdir(Path, (err, files) => { // err && console.warn('路径读取出错', err); //遍历读取到的文件列表 files.forEach((filename) => {

2021-08-05 09:41:16 405

原创 promise多个链式执行

promise情况下多个异步请求链式请求场景今天碰到文件上传,上传多张只会收到一张,由于调一次接口只能上传一张图片,原本我是用循环调接口,并行的请求,后来后端要求单个并且链式调用,等前一个接口返回了才调下一个解决由于不定个数肯定是只能通过数据遍历的形式去调用接口,顺序+数组我就想到了reuduce方法,虽然自己的想法没有成功,试错过程发现:js数组的高阶函数这些的函数体执行了异步代码时,即使使用async await,也是所有循环的同步代码执行完,采取执行异步代码(高阶函数就是类似ma

2021-07-22 15:38:15 238

原创 typescript中的高级类型

typescript中的高级类型Partial将一个类型所有参数转换为可选type Partial <T> { [P in keyof T]?:T[P]}type Man { sex:string, age:number}type ManPartial = Partial<Man> // 这样我们就可以在后续中使用空对象定义一个带有类型的值let obj:ManPartial | any = {}Exclude取出T中除了U以外的,即取出T有U没有的

2021-06-04 14:56:07 217

原创 el-table上下键高亮当前行

el-table上下键高亮当前行数据值定义data () { return { // 表格跳过的行高 skipRowHeight: {}, // 超出视口高的索引 overViewIndexArr:[], // 当前行索引 currentchangeData:0, // 表格数据 tableData:[] }}添加键盘监听activated () { document.addEventListener('keydown'

2021-05-10 19:49:40 764

原创 路由搭建

搭建权限管理系统-02路由搭建目录结构路由结构代码import { createRouter, createWebHashHistory, RouteRecordRaw } from 'vue-router'import Layout from '@/view/layout/index.vue'const lazyImport = (path: string) => { return () => import(`@/view${path}`)}console.log(laz

2021-03-27 15:45:25 823

原创 搭建权限管理系统-01安装

搭建权限管理系统-01安装vue+typescript+vue-router+vuex+element-plus安装脚手架vue create admin-test选择vue3.0typescriptrouterstorejestcss-process(node-sass) 官方貌似建议使用dart-sasseslint安装Element-plus这里一开始使用添加插件的形式 vue add element-plus,安装完成之后webpack在编译之后出现了根目录下的main

2021-03-27 15:43:59 162

原创 vue解析展示有组件的字符串

vue解析展示有组件的字符串今天是()月()号?对上面的文字做成填空题的形式,括号能够进行输入1.解析字符串let str = '今天是(_)月(_)号?'let reg = /(\(_*\))/glet res = Array.from(str.match(reg))res.forEach((item, index) => { // 这里就是双向数据绑定的答案对象,有由于不知道有几个空采用$set的形式就行设置 this.$set(this.blankAnswerObj,

2021-01-20 15:55:23 1120

原创 promise工作中应用

promise工作中的实际应用这周在工作开发中碰到了一个场景,就是a函数的请求参数依赖于b函数的请求返回结果代码:methods:{ getId(){ this.$http(url).then(res =>{ console.log(res) }).catch(err => console.log(err)) }, getData(){ this.getId() //相关请求 }}上面代码的意思表示,getData()函

2020-08-21 21:27:50 337

原创 el-table行内编辑

el-table的行内编辑本周开发遇到了需要能够在element-ui的el-tabe组件中实现行内编辑啥也不说先放代码html<el-table :data="tableData" style="width: 100%" @row-click="handleRowClick"> <el-table-column prop="date" label="日期" width="180"> </el-table-column> <el-table-c

2020-08-21 21:26:14 3106 1

原创 vue中表单赋值无法响应式,输入框无法改变值

开发中碰到,使用element-ui输入框时无法赋值,输入无反应原因:1.细节性错误使用el-form标签时,其中的el-form-item对应的prop属性值,v-model绑定值,data对象中的字段值三者出现不一致代码示例html:<el-form-item prop="name"> <el-input v-model="form.name"></el-input></el-form-item>js:data(){ retu

2020-08-15 12:47:14 10646 10

原创 封装小程序的请求

对小程序官方的wx.request进行再次封装最近在学习小程序的时候,学习到了对于官方的请求方法的再次封装话不多说上代码let times = 0export const myRequest = (params) =>{ times++ wx.showLoading({ title: '加载中', mask: true, }) return new Promise((resolve,reject)=>{ wx.request({ .

2020-06-19 23:07:54 125

原创 src和href的区别

src和href的区别src的会先将使用该属性的标签引用资源加载完成之后再进行下面的加载,如<script>拿“script”标签举例来说,当浏览器解析到这个标签时,会暂停其他资源的加载,知道script标签加载完毕之后才会继续加载其他内容,这也是为什么建议将该标签放在页面后方打的原因href则在加载引用资源的同时会继续对问当进行处理,如<link href="index.css" rel="stylesheet">处理css时,浏览器会并行下载资源不会停止对文档的加载

2020-06-08 15:44:17 142

原创 js函数作用域中的优先级

js函数作用域中的优先级首先直接上结论:变量提升 < 传参 < 函数体 < 首行赋值变量提升function fn(){ console.log(a) var a = 1}fn() //输出为 undefined如果将var替换成ES6中的let和const会因为暂时性死区而报错传参function fn(a){ console.log(a) var a = 1}fn(2) //输出为2从而可以得出,变量提升的优先级低于函数传参函数体

2020-05-31 13:32:29 762

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除