记录一些在开发中遇到的比较常用的小技巧
如何知道iframe下载完成
实现思路:定时器去监听readyState的状态,如果是 complete 或者 interactive 则说明文件加载完成。
let iframe = document.createElement('iframe');
iframe.src = path;
iframe.style.display = 'none';
document.body.appendChild(iframe);
const timer = setInterval(() => {
const iframeDoc = iframe.contentDocument || iframe.contentWindow.document;
if (iframeDoc.readyState == 'complete' || iframeDoc.readyState == 'interactive') {
document.body.removeAttribute(iframe);
clearInterval(timer);
resolve('success');
}
}, 1000);
全屏居中js函数
//获取元素
function getElement(ele) {
return document.getElementById(ele);
}
//自动居中函数
function autoCenter(el) {
var bodyX = document.documentElement.offsetWidth || document.body.offsetWidth;
var bodyY =
document.documentElement.offsetHeight || document.body.offsetHeight;
var elementX = el.offsetWidth;
var elementY = el.offsetHeight;
el.style.left = (bodyX - elementX) / 2 + "px";
el.style.top = (bodyY - elementY) / 2 + "px";
}
JS实现深拷贝
function getType(obj) {
// 为啥不用typeof? typeof无法区分数组和对象
if(Object.prototype.toString.call(obj) == '[object Object]') {
return 'Object';
}
if(Object.prototype.toString.call(obj) == '[object Array]') {
return 'Array';
}
return 'nomal';
};
function deepCopy(obj) {
if (getType(obj) == 'nomal') {
return obj;
} else {
var newObj = getType(obj) == 'Object' ? {} : [];
for(var key in obj) {
// 为啥要用hasOwnProperty?不需要从对象的原型链上进行复制
if(obj.hasOwnProperty(key)) {
newObj[key] = deepCopy(obj[key]);
}
}
}
return newObj;
}
var object = [
{
title: 'test',
checked: false
}
];
deepCopy(object);
生成星级评分
const StartScore = rate => "★★★★★☆☆☆☆☆".slice(5 - rate, 10 - rate);
const start = StartScore(3);
// start => "★★★"
JS数组扁平化
toString
const arr = [1, 2, 3, [4, 5, [6, 7]]];
const flatten = arr.toString().split(',');
console.log(flatten);
好处:简单,方便,对原数据没有影响
坏处:最好数组元素全是数字或字符,不会跳过空位
join
const arr = [1, 2, 3, [4, 5, [6, 7]]];
const flatten = arr.join(',').split(',');
console.log(flatten);
好处和坏处跟上面的 toString() 一样
flat
const arr = [1, 2, 3, [4, 5, [6, 7]]];
const flatten = arr.flat(Infinity);
console.log(flatten);
好处:会跳过空位,返回新数组,不会修改原数组
扩展运算符 (...)
const arr = [1, 2, 3, [4, 5]];
console.log([].concat(...arr));
好处:简单,方便
坏处:只能作用第一层
使用 :not() 来精简css代码
// 不使用:not()
.nav li {
border-right: 1px solid #666;
}
.nav li:last-child {
border-right: none;
}
// 使用:not()
.nav li:not(:last-child) {
border-right: 1px solid #666;
}
// 或者使用兄弟选择符~
.nav li:first-child ~ li {
border-left: 1px solid #666;
}
文本溢出处理
移动设备相对来说页面较小,很多时候显示的一些信息都需要省略部分。
最常见的是单行标题溢出省略,多行详情介绍溢出省略。
现在都用框架开发了,这种建议需求建议形成一个基础组件,方便快捷
//单行
.single {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
//多行
.more {
display: -webkit-box !important;
overflow: hidden;
text-overflow: ellipsis;
work-break: break-all;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2; //指定行数
}
JS实现列表操作
function list() {
this.dataStore = []; //初始化数组
this.clear = clear; //清除列表
this.remove = remove; //移除列表中的元素
this.find = find; //寻找列表中的元素
this.length = length; //返回列表的长度
}
function find(element) {
for (var i = 0, len = this.dataStore.length; i < len; i++) {
if (this.dataStore[i] === element) {
return i;
}
}
return -1;
}
function remove(element) {
for (var i = 0, len = this.dataStore.length; i < len; i++) {
if (this.dataStore[i] === element) {
this.dataStore.splice(i, 1);
}
}
return this.dataStore;
}
function length() {
return this.dataStore.length;
}
function clear() {
this.dataStore = [];
}
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!