常用代码收集
JavaScript
获取URL的查询参数
这个获取URL的查询参数代码,是我见过最精简的QAQ
?foo=bar&baz=bing => {foo: bar, baz: bing}
// 获取URL的查询参数
const q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);
对象转换成URL查询参数
// 对象转换成URL查询参数
function objectToQueryString(obj) {
return Object.keys(obj)
.map(key => encodeURIComponent(key) + '=' + encodeURIComponent(obj[key]))
.join('&');
}
const url = 'http://localhost:3000/demo/';
const queryString = objectToQueryString(params);
window.location.href = `${url}?${queryString}`;
URL编码和解码
decodeURI() 函数可对 encodeURI() 函数编码过的 URI 进行解码。
var test1="http://www.w3school.com.cn/My first/"
// 字符串 URI 进行编码。
console.log(encodeURI(test1))
// 字符串 URI 进行解码。
console.log(decodeURI(test1))
生成随机ID
在原型设计时经常使用的创建ID功能。但是我在实际项目中看到有人使用它。其实这并不安全
// 生成长度为11的随机字母数字字符串
Math.random().toString(36).substring(2);
// hg7znok52x
生成随机十六进制代码(生成随机颜色)
使用JavaScript简洁代码生成随机十六进制代码
// 生成随机十六进制代码 如:'#c618b2'
'#' + Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, '0');
获取身份证信息
idCardData(iDCard){
// 根据身份证号获取出生日期
const birthday = new Date(iDCard.substring(6, 10) + '-' + iDCard.substring(10, 12) + '-' + iDCard.substring(12, 14))
// 根据身份证号获取性别
const sex = (()=>{if (parseInt(iDCard.substr(16, 1)) % 2 == 1) { return '0' } else { return '1' }})()
//根据身份证号获取年龄
const age = new Date().getFullYear() - iDCard.substring(6, 10) - 1
return { birthday, sex, age}
}
CSS
clearfix通用清除浮动
/* 清除浮动对父类元素的影响 */
.clearfix:before,
.clearfix:after {
content: '';
display: table;
}
.clearfix:after {
clear: both;
}
溢出的文字以省略号形式显示
/*单行溢出*/
.one-txt-cut {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
/*多行溢出*/
.txt-cut {
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
}
浏览器原生滚动条样式调整
// 定义滚动条高宽及背景
// 高宽分别对应横竖滚动条的尺寸
::-webkit-scrollbar {
width: 10px;
height: 10px;
background-color: transparent;
}
// 定义滚动条轨道
::-webkit-scrollbar-track {
border-radius: 6px;
background-color: transparent;
}
// 定义滑块
::-webkit-scrollbar-thumb {
border-radius: 6px;
border: 2px solid transparent;
background: rgba(144, 147, 153, 0.3);
background-clip: padding-box;
transition: all 0.3s;
}
// 定义滑块
::-webkit-scrollbar-thumb:hover {
border-radius: 10px;
background: #c0bcbc;
border-color: #c0bcbc;
}
使用vw定制rem自适应布局
/* 基于UI width=750px DPR=2的页面 */
html {
font-size: calc(100vw / 7.5);
}
使用writing-mode排版竖文
- 要点:通过
writing-mode
调整文本排版方向 - 场景:竖行文字、文言文、诗词
- 兼容:writing-mode
- 代码:在线演示
<div class="vertical-text">
<h3>情</h3>
<p>我见犹怜,<br>爱不释手。<br>雅俗共赏,<br>君子好逑。</p>
</div>
.vertical-text {
writing-mode: vertical-rl;
}
ElementUI复选按钮变单选按钮
场景:单选按钮可以切换单个值
/**
* @author ZhenYuTsai
* @description element复选框样式变单选框样式
*/
.z-radio{
.el-checkbox__inner{
border: 1px solid #dcdfe6;
border-radius: 100%;
width: 14px;
height: 14px;
background-color: #fff;
position: relative;
cursor: pointer;
display: inline-block;
box-sizing: border-box;
}
.el-checkbox__inner::after{
width: 4px;
height: 4px;
border-radius: 100%;
background-color: #fff;
content: "";
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%,-50%) scale(0);
border: none;
}
.el-checkbox__input.is-checked .el-checkbox__inner:after {
transform: translate(-50%,-50%) scale(1);
}
}
插件
生成带图片的二维码
npm install qrcode-with-logos --save
项目内部预览打印PDF文件
npm install pdfh5 --save
element-ui 的表格与无限滚动的结合
npm install el-table-infinite-scroll --save
纯前端下载文件
npm install web-downloadfile --save