Category: JS

  • 常用的 JS 代码片段

    01:将内容复制到剪贴板

    const copyToClipboard = (content) => {
        const textarea = document.createElement("textarea")
      
        textarea.value = content
        document.body.appendChild(textarea)
        textarea.select()
        document.execCommand("Copy")
        textarea.remove()
    }

    02:使用URLSearchParams获取URL的搜索参数

    const getQueryByName = (name) => {
        const query = new URLSearchParams(location.search)
        return decodeURIComponent(query.get(name))
    }
    
    // url: https://sunday.com/?name=fatfish&age=100
    const name = getQueryByName('name') // fatfish
    const age = getQueryByName('age') // 100
    const gender = getQueryByName('gender') // null

    03:平滑滚动至页面顶部

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

    04:获取当前页面滚动距离

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

    05:格式化货币

    const formatMoney = (money) => {
        return money.toLocaleString()
    }
    
    formatMoney(123456789) // '123,456,789'
    formatMoney(123456789.123) // '123,456,789.123'
    formatMoney(123) // '123'

    06:进入和退出全屏

    // 进入全屏
    function fullScreen() {
      let el = document.documentElement
      let rfs = el.requestFullScreen || el.webkitRequestFullScreen || el.mozRequestFullScreen || el.msRequestFullScreen
      //typeof rfs != "undefined" && rfs
      if (rfs) {
        rfs.call(el)
      } else if (typeof window.ActiveXObject !== "undefined") {
        let wscript = new ActiveXObject("WScript.Shell")
        if (wscript != null) {
          wscript.SendKeys("{F11}")
        }
      }
    }
    // 退出全屏
    function exitScreen() {
      let el = document
      let cfs = el.cancelFullScreen || el.webkitCancelFullScreen || el.mozCancelFullScreen || el.exitFullScreen
      //typeof cfs != "undefined" && cfs
      if (cfs) {
        cfs.call(el)
      } else if (typeof window.ActiveXObject !== "undefined") {
        let wscript = new ActiveXObject("WScript.Shell")
        if (wscript != null) {
          wscript.SendKeys("{F11}")
        }
      }
    }
  • VUE+VITE

    1、创建vue3项目

    npm create vite@latest

    输入项目的名字(作者就用test了)

    Project name: » vite-project

    按上下选择框架,这就选vue然后回车

    √ Project name: ... test
    ? Select a framework: » - Use arrow-keys. Return to submit.
        Vanilla
    >   Vue
        React
        Preact
        Lit
        Svelte

    选择ts

    ? Select a variant: » - Use arrow-keys. Return to submit.
        JavaScript
    >   TypeScript
        Customize with create-vue
        Nuxt

    然后控制台出现后面这三条命令,cv就行

    Done. Now run:
      cd test
      npm install
      npm run dev

    2、安装less/scss

    由于是使用vite,vite它提供了对 .scss, .sass, .less, .styl 和 .stylus 文件的内置支持,但必须安装相应的预处理器依赖;

    国内一般只使用 less 或 scss,所以我只写这两个安装

    安装less依赖

    npm add -D less 

    安装scss  and  sass 依赖

    npm add -D sass 

    安装后可以直接使用less了  ,当然,也可以使用scss,一般只下一个就够了,我比较推荐scss