几个解决实际问题的ES6代码段

Posted chailug

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了几个解决实际问题的ES6代码段相关的知识,希望对你有一定的参考价值。

1、如何获取当前页面的滚动位置?

 const getScrollPosition = (el = window) => ({  
      x: el.pageXOffset !== undefined ? el.pageXOffset : el.scrollLeft,  
      y: el.pageYOffset !== undefined ? el.pageYOffset : el.scrollTop  
   });  
 getScrollPosition(); // {x: 0, y: 200}

2、如何平滑滚动到页面顶部?

const scrollToTop = () => {  
      const c = document.documentElement.scrollTop || document.body.scrollTop;  
      if (c > 0) {  
        window.requestAnimationFrame(scrollToTop);  
        window.scrollTo(0, c - c / 8);  
      }  
    };  
scrollToTop();    

3、如何分辨设备是移动设备还是桌面设备?

const detectDeviceType = () =>  
      /android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent) ? ‘Mobile‘ : ‘Desktop‘;  
    // Example  
detectDeviceType(); // "Mobile" or "Desktop"

4、如何将一个字符串复制到剪贴板?

const copyToClipboard = str => {  
      const el = document.createElement(‘textarea‘);  
      el.value = str;  
      el.setAttribute(‘readonly‘, ‘‘);  
      el.style.position = ‘absolute‘;  
      el.style.left = ‘-9999px‘;  
      document.body.appendChild(el);  
      const selected =  
        document.getSelection().rangeCount > 0 ? document.getSelection().getRangeAt(0) : false;  
      el.select();  
      document.execCommand(‘copy‘);  
      document.body.removeChild(el);  
      if (selected) {  
        document.getSelection().removeAllRanges();  
        document.getSelection().addRange(selected);  
      }  
    };  
// Example  
copyToClipboard(‘Lorem ipsum‘); // ‘Lorem ipsum‘ copied to clipboard.

完结

2020-11-05 15:57:59

以上是关于几个解决实际问题的ES6代码段的主要内容,如果未能解决你的问题,请参考以下文章

使用 Jest 模拟 Es6 类

Chrome-Devtools代码片段中的多个JS库

sublime新代码段

超实用的php代码片段

ES6 模块串联

一日一技:如何从多个Jupyter Notebook中找到需要代码段