最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 前端业务常用技巧记录

    正文概述 掘金(桐庐sama)   2020-12-19   452

    记录一些在开发中遇到的比较常用的小技巧

    如何知道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介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元