自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(113)
  • 资源 (22)
  • 收藏
  • 关注

原创 js方------将字符串转换成算术表达式,并计算出结果,例如(‘92-4*5/3‘)

// 计算当前字符串是否是数字 const isNumber = (val) => { const regPos = /^\d+(\.\d+)?$/ // 非负浮点数 const regNeg = /^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$/ // 负浮点数 if (regPos.test(val) || regNeg.test(v..

2021-11-12 18:39:41 4968 2

原创 js方法-通过出生日期计算出当前年龄

/*** 通过出生日期获取当前年龄* @param strBirthday:指的是出生日期,格式为"1990-01-01",字符串类型*/function getCurrentAgeByBirthDate(strBirthday){ // 将出生日期的字符串通过"-"分割成数组 const strBirthdayArr = strBirthday.split("-") // 拿到出生日期的年 const birthYear = strBirthdayArr[0]

2021-09-08 18:05:20 4121 1

原创 js方法——时间处理方法

function GetDateStr(AddDayCount) { var dd = new Date(); dd.setDate(dd.getDate()+AddDayCount); //获取AddDayCount天后的日期 var y = dd.getFullYear(); var m = (dd.getMonth()+1)<10? "0" +(dd.getMonth()+1):(dd.getMonth()+1); //获取当前月份的日期,不足10

2021-05-26 15:45:06 236

原创 js——将列表数据处理成树型结构数据

/** * 构造树型结构数据 * @param {*} data 数据源 * @param {*} id id字段 默认 'id' * @param {*} parentId 父节点字段 默认 'parentId' * @param {*} children 孩子节点字段 默认 'children' * @param {*} rootId 根Id 默认 0 */export function handleTree(data, id, parentId, children, rootId) {

2021-05-19 10:17:57 562

原创 Ant Design Vue的图片上传组件的使用

<div class="clearfix"> <a-upload :customRequest="uploadImg" :remove="handleRemove" list-type="picture-card" :file-list="fileList" @preview="handlePreview"

2021-05-11 12:52:10 2059

原创 小程序开发(如何手动触发当前页的onLoad生命周期)

// 获取当前页面栈的实例// 获取当前页面栈。数组中第一个元素为首页,最后一个元素为当前页面const pages = getCurrentPages()// 拿到当前页面的实例const page = pages.pop()// 手动执行 onLoad 生命周期函数page.onLoad()...

2021-04-20 16:49:53 1108

原创 微信小程序开发——单行文本溢出显示省略号

.text-deal{ overflow : hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; word-break: break-all; /* 追加这一行代码 */}/*-webkit-line-clamp为3,代表三行后超出隐藏加省略,常用为1。*/...

2021-04-15 13:05:22 763

原创 js截取字符串方法slice、substring、substr的理解

const test = 'hello' // 字符串长度为 5 // string.slice(start, end) // 提取一个字符串,从起始位置截取,不包含结束位置 start:开始索引 end:结束索引 // string.substring(start, end) // 提取一个字符串, end不支持负数,从起始位置截取,不包含结束位置 start:开始索引 end:结束索引 // string.substr(start,len) .

2021-03-21 18:37:47 221

原创 前端面试题-给定一个字符串,找出其中无重复字符的最长子字符串长度

// 给定的字符串 const str = 'abac' function outputMaxSubStrLen(str) { let result = 0; // 最终要返回的结果的初始值 let norepeatStr = ''; // 用于存放无重复子串 let len = str.length; // 字符串的长度 // 遍历整个字符串 .

2021-03-20 20:32:13 467

原创 前端面试题-确保字符串的每个单词首字母都大写,其余部分小写

// 给定的字符串 const str = 'aaa bBB CCC dDD' // 确保字符串的每个单词首字母都大写,其余部分小写 function toUpperCase(str) { // 将字符串以空格分割成数组 let arr = str.split(' ') // 对数组内容进行处理 arr = arr.map(item => item[0].t

2021-03-20 17:15:29 417

原创 前端面试题-编写函数parseQueryString,它的用途是把URL参数解析为一个对象

// 给定的url参数 const url = 'http://127.0.0.1:8888/api?model=job&action=list?' // 将 URL 参数解析为一个对象 function parseQueryString(url) { // 存放查询参数字符串 let queryInfo = '' // 存放一个对象 const obj .

2021-03-20 17:00:53 1176

原创 前端面试题-计算出字符串中出现次数最多的字符是什么?出现了多少次?

// 给定的字符串 const str = 'abcabc' // 统计字符串中出现次数最多的字符,出现多少次 function statistics(str) { // 声明一个变量 const obj = {} // 存放出现次数最多的字符 let maxStr = '' // 存放出现的次数 let max =

2021-03-20 16:25:30 812

原创 前端面试题-写一个js函数,实现对一个数字每3位加一个逗号(不考虑负数,小数)

// 相当于封装字符串的 toLocaleString 方法 // const str = num.toLocaleString()// 给定的数字(不考虑负数,小数) const num = 100000 // 实现对一个数字每3位加一个逗号,如输入100000,输出100,000(不考虑负数,小数) function toLocaleString(num) { // 将数字转换成字符串,并分割成数组 /

2021-03-19 22:27:29 1424

原创 冒泡排序的简单实现

const arr = [2, 4, 45, 5, 1, 2, 13] // 外层for循环管趟数(数组长度 -1) for (let i = 0; i <= arr.length - 1; i++) { // 内层for循环管每一趟的交换次数(当前趟数 -1) for (let j = 0; j <= arr.length - i - 1; j++) { // 如果当前项与后一项.

2021-03-14 14:29:55 69

原创 对external的理解

external在 vue.config.js 文件中的 configureWebpack 对象下面例子:// 要排除的包名// key(是要排除的包名): value(实际上是实际引入的包的全局的变量名)// 因为要排除 element-ui 所以后面要引入 CDN 文件,CDN 文件中有 ELEMENTUI 的全局变量名// webpack打包的时候会根据 externals 的配置,首先会排除掉定义的包名(这些包不需要打包)// 空出来的位置,会用变量来替换 externals = {

2021-03-12 11:58:05 901

原创 浏览器全屏功能的实现

用原生js实现全屏功能document.documentElement.requestFullscreen() // 开启全屏document.exitFullscreen() // 关闭全屏用插件实现全屏功能// 在 vue 中// 第一步 下载插件 $ npm i screenfull// 第二步 导入插件 import ScreenFull from 'screenfull'// 第三步 给全屏按钮绑定点击事件 // 第四步 全屏按钮点击事件触发的函数changeScreen ()

2021-03-11 20:39:56 150

原创 一次性注册所有公共组件

在mian.js入口文件中@ 相当于 src 目录import Components from '@/components/index.js'// 注册所有自定义的公共组件Vue.use(Components)在 src 目录下的 components 文件的 index.js 中// 导入组件import PageTools from './PageTools/index.vue'// 默认导入一个对象export default { // 当使用 Vue.use() 方法的时候,

2021-03-04 11:53:56 95 1

原创 一次性注册所有自定义指令(过滤器也可适用)

在入口文件mian.js中import * as directives from '@/directives'import * as filters from '@/filters'// 注册所有自定义指令Object.keys(directives).forEach(key => Vue.directive(key, directives[key]))// 注册所有过滤器Object.keys(filters).forEach(key => Vue.filter(key, fil

2021-03-04 11:45:18 117 1

原创 处理分页的页面最后一条数据的注意点

// 在发送请求前,查看删除的那条数据是否是当前页最后一条数据,如果是,则更新查询参数,而且要注意,如果是第一页的最后一条数据,不需要更新 // 如果删除的是当前页最后一条数据 if (this.queryInfo.pagesize === 1) { // 如果删除的不是第一页的最后一条数据 this.queryInfo.page !== 1 && this.queryInfo.page-- }...

2021-03-04 10:10:58 447 1

原创 将列表类型的数据转换为树形数据

列表的数据const depts = [{ "id": "1175310929766055936", "pid": "", "companyId": "1", "name": "总裁办", "code": "ZCB1", "managerId": null, "manager": "孙财", "introduce": "总裁办公室", "createTime": null }, { "id": "1175311213774962688", "pid": "", "companyId": "1", "nam

2021-03-01 18:41:55 517 2

原创 vue组件的属性functional的理解

functional为true,表示该组件为一个函数式组件函数式组件:没有data状态,没有响应式数据,只会接受props属性,没有this,他就是一个函数

2021-02-28 19:26:31 1020

原创 查看或设置npm的镜像地址

前提条件:已经搭建了 node 环境,nodejs是当下前端工程化开发必不可少的环境, 使用 nodejs 的 npm 功能来管理依赖包npm是非常重要的npm管理工具,由于npm的服务器位于国外, 所以一般建议 将 npm设置成国内的淘宝镜像,在终端中执行以下命令$ npm config set registry https://registry.npm.taobao.org/ #设置淘宝镜像地址查看当前 npm 的镜像地址$ npm config get registry #查看镜像地址

2021-02-23 09:12:58 15552

原创 封装节流(throttle)函数

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> div {

2021-01-18 20:43:05 756

原创 对函数封装的理解

函数封装不要替调用者决定做什么事情

2021-01-18 20:04:01 408

原创 对防抖(debounce)和节流(throttle)的理解

防抖(debounce)和节流(throttle)都是性能优化的一种手段debounce:重复触发(事件)不执行,不触发的一段时间后才执行throttle:重复触发(事件)也执行,只不过执行的频率变低了

2021-01-18 19:40:21 178

原创 对小程序开发中的顶级对象wx身上的基于回调函数的api进行promise化

第一步:在终端中执行 npm install --save [email protected]第二步: 删除目录中的 miniprogram_npm 文件夹,并重新构建啊npm第三步:在app.js中添加以下代码//app.js// 按需导入 promisefyAll 方法import { promisifyAll } from 'miniprogram-api-promise'// 将新创建的对象 wxp 的引用地址给 wx 的属性 pconst wxp = wx

2021-01-04 15:02:32 226

原创 在小程序开发中导入 vant Weapp 组件库的包

第一步:通过 npm 安装 vant Weapp 包在终端中执行 npm i @vant/weapp -S --production第二步:将 app.json 中的 “style”: “v2” 去除,小程序的新版基础组件强行加上了许多样式,难以覆盖,不关闭将造成部分组件样式混乱。第三步:修改 project.config.json。{…“setting”: {…“packNpmManually”: true,“packNpmRelationList”: [{“packageJsonPa

2021-01-04 14:54:16 203 1

原创 小程序开发者工具设置格式化换行长度

问题:微信小程序开发者平台中的js格式化不能设置换行长度,只要是对象就会换行解决方法: 在设置的json 文本中添加以下代码“beautify.config”: {“brace_style”: “collapse-preserve-inline”,“wrap_line_length”: 200},...

2021-01-04 14:42:44 1446 2

原创 vuex模板(对token的处理)

import Vue from 'vue'import Vuex from 'vuex'// 按需导入本地存储相关的模块import { setItem, getItem } from '@/utils/storage'Vue.use(Vuex)// 声明一个常量,保存token的名字,防止读取和写入本地存储的时候写错const TOKEN_KEY = 'TOUTIAO_USER'// 默认导出export default new Vuex.Store({ state: { /

2020-12-25 14:07:55 134

原创 vue工具(封装请求方法)

// 封装请求方法import axios from 'axios'import store from '@/store'const request = axios.create({ baseURL: '请求的基准路径'})// 请求拦截器request.interceptors.request.use(function (config) { // 请求发起会走这里 // 拿到容器中保存的token数据 const user = store.state.user // 如

2020-12-25 14:05:47 375

原创 vue工具(封装本地存储相关的操作模块)

/** * 本地存储相关的操作模块 *//** * 写入数据 */export const setItem = (key, data) => { // 如果存入的是对象、数组类型的数据 if (typeof data === 'object') { // 将数据转换为json字符串格式 data = JSON.stringify(data) } window.localStorage.setItem(key, data)}/** * 读取数据 *

2020-12-25 13:58:16 162

原创 正则表达式匹配 带有特殊字符的字符串失败(特殊字符指: . ? + $ ^ [ ] ( ) { } | \ / )

特殊字符有: . ? + $ ^ [ ] ( ) { } | \ /匹配不成功的示例:const str = '(hehe)43'const reg = new RegExp(str,'gi') // reg : /(hehe)43/ 括号未做转义处理console.log(reg.test(str)) // 结果是 false匹配不成功的原因:str 中的字符串中的特殊字符没有做转义处理如果想匹配成功,就要先对str中的特殊字符做转义处理匹配成功的示例:const str = '(

2020-12-18 16:19:35 3247 1

原创 封装防抖(debounce)函数

将下面的代码粘贴到调试工具中运行一下,然后滚动页面,就可以看到时哪个元素产生的滚动了。function findscroller(element) {element.onscroll = function() {console.log(elemnet)}Array.from(element.children).forEach(findscroller)}findscroller(document.body)...

2020-12-13 21:51:26 416

原创 node.js习题(设置允许跨域访问服务)

// 设置允许跨域访问该服务app.all('*', function (req, res, next) { res.header('Access-Control-Allow-Origin', '*'); res.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS'); res.header('Access-Control-Allow-Headers', 'X-Requested-With'); r

2020-11-24 08:59:08 277

原创 Vue习题(自定义一个全局指令,让输入框自动获取焦点)

/* 自定义全局指令:获取输入框焦点 */ Vue.directive('focus', { inserted: function (el) { return el.focus() } })

2020-11-18 08:39:33 313

原创 Vue习题(写一个格式化时间的过滤器)

/* 过滤器案例:格式化日期 */ Vue.filter('formatDate', function (date, format) { if (typeof date === "string") { var mts = date.match(/(\/Date\((\d+)\)\/)/); if (mts && mts.length >= 3) { date = parseInt(

2020-11-16 21:32:43 202

原创 js习题(将html中的特殊字符转义和还原)

//定义一个转换html转义特殊字符的方法function htmlEscape(htmlStr) { return htmlStr.replace(/[<>|"&]/g, (match) => { switch (match) { case '<': return '&lt;'; case '>': return '&gt;'; case '"': ret

2020-11-07 22:21:12 1324 1

原创 template模板引擎中的格式化时间的过滤器

// 定义一个美化时间的过滤器 template.defaults.imports.dataFormat = function (data) { const date = new Date(data); let y = date.getFullYear(); let m = (date.getMonth() + 1).toString().padStart(2, 0); let d = date.getDate().toString().padStart(2, 0);

2020-11-03 11:24:18 688

原创 js习题(用原生js封装Ajax函数)

以下是js代码:/** * 处理data参数 * @param data{Object} 需要发送到服务的数据 * @return {String} 返回拼接好的查询字符串 * @author 不知猫 2020/10/26 */function resolveData(data) { const arr = []; for (let key in data) { arr.push(key + '=' + data[key]); } return arr.join('&a

2020-10-26 22:22:56 233

原创 js习题(浅拷贝的方法)

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title></head><body></body>

2020-10-20 16:57:03 75

数据可视化项目.rar

今天刚做完的作品,主要是学echarts

2020-10-16

01-移动端轮播图.rar

学习做轮播图时的,老师的样本,csdn太垃圾了,总是不停的改积分,如果有其他更好的可以上传资源的地方,请告诉我

2020-10-07

优惠活动(移动端页面).rar

这是我学习移动端页面制作的时候的学习作品,里面有四个页面,需要的图片素材都在里面,psd图也有。csdn太垃圾了,总是改积分,如果有其它更好的博客请推荐给我

2020-09-10

登录页面(移动端).rar

这是我学移动端页面制作的时候做的,做的有些粗糙的请多多包含,制作这个页面不需要图片素材,里面涉及到背景渐变,弹性盒子

2020-09-09

阿里百秀(移动端页面).rar

这是我学习移动端页面开发中的作品之一,做的不是很好,制作网页需要的图片素材都在压缩包里。

2020-09-08

易康问答(移动端页面.rar

这是我刚开始学移动端页面制作时做的,做的很粗糙,内含制作网页需要的图片素材,练习移动端的可以试试练习一下

2020-09-08

小米首页(内含图片素材).rar

学完html和css基础就可以独立制作的网页,制作网页需要的图片素材都在压缩包中,这是本人独立制作的网页,可以用它来锻炼自己的布局能力

2020-08-26

百度糯米(内含图片素材).rar

学完html和css基础就可以独立制作的网页,需要的图片素材都在压缩包中,可以写它来练习自己网页布局的能力

2020-08-25

登录页面——万里长城.zip

学完html和css基础就可以独立制作的网页,需要的素材里面都有,可以用它来检验自己的学习成果,非常简单的网页,初学者的作品

2020-08-25

oppo(内含图片素材).rar

学完html和css基础就可以独立制作的网页,制作网页的图片素材都在压缩包中,可以用它来检验自己的水平

2020-08-25

金山云(内含图片素材).rar

学完html和css基础就可以独立完成的网页,完成网页需要的图片素材都在压缩包,里面的网页底部的二维码交互效果是用jquery做出来的

2020-08-25

静态太极图(css考试试题).rar

学完html和css就可以独立制作的网页,写这个太极需要用到css的伪元素和定位,可以锻炼自己的编程思维

2020-08-24

仿小米logo.rar

学完html和css基础就可以独立制作的logo,这是一个仿照小米页面写的logo,需要用到伪元素知识,可以用写它来检验自己的水平

2020-08-24

好知网(html和css基础考试试题).rar

这是一个学完htm和css基础就可以独立制作的网页,做这个网页可以检验自己学完html和css的水平,里面包含需要的素材 l

2020-08-24

学成在线(html和css考试试题).rar

这是一个学完html和css基础课程就可以独立制作的网页,可以用来检验自己的布局水平,看看自己还有那些不足

2020-08-24

金山云素材(金山云网页的其中一个小模块).rar

黑马考试基础班考试时做的,学完html和css就可以做的网页,可以检验一下自己的html和css水平

2020-08-24

淘宝搜索框.zip(含jquery1.12.4包代码)

和淘宝网页的输入框一模一样的效果,在输入框输入文字的时候(不是鼠标聚焦和点击的时候),默认图标放大镜和默认文字消失,在输入框没有输入文字但焦点还在的时候,默认图标和默认文字出现

2020-07-26

淘宝右侧固定导航定位.zip

模仿淘宝首屏页面的右侧固定定位导航栏写的,功能到不难写,但是有个问题花了我一上午的时间,每次点击的时候总是跳到页面顶部(后来发现是刷新),找了半天办法,最后总算解决了,如果你遇到同样的问题,可以看下我的代码

2020-07-24

淘宝搜索框(和淘宝网页的输入框一样的效果).zip

和淘宝网页的输入框一模一样的效果,在输入框输入文字的时候(不是鼠标聚焦和点击的时候),默认图标放大镜和默认文字消失,在输入框没有输入文字但焦点还在的时候,默认图标和默认文字出现

2020-07-23

jquery-1.12.4免费.zip

找了好久才找到一个网站下了jquery-1.12.4的代码,学习不易,尤其是自学的人,学习资源难找啊

2020-07-22

贪吃蛇游戏小开发(内含图片素材,源代码).zip

只用html和css和JavaScript写,没用其它任何语言,适用于刚接触前端,刚学完html,css,JavaScript的人练手用

2020-07-21

静态轮播图(只用HTML和css)

只用html和css写代码,有左右按钮,有浮点导航栏,鼠标移动到哪个左右按钮或浮点,那个按钮和浮点就会变色

2020-07-17

空空如也

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

TA关注的人

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