✏️
ougege
  • README
  • Docs
    • index
    • Articles
      • AI
        • 体验Chrome AI
        • 体验Cloudflare Workers AI
        • 体验deepseek
      • CSS
        • CSS优化-PurgeCSS
        • 实用效果
        • 开发常用样式
      • Deepin
        • deepin20安装mysql
        • deepin使用tensorflow入门机器学习
        • deepin安装cuda和cuDNN
        • deepin安装lamp
        • deepin安装nvidia驱动
        • deepin安装oh my Zsh
        • deepin安装p7zip
        • deepin换源
        • 安装deepin系统后要做的事
      • Docker
        • CI/CD搭建配置
        • deepin搭建docker环境
        • docker安装和使用gitlab
        • docker搭建nginx+php环境
      • Essay
        • IOS申请邓白氏编码
        • Markdown-Mermaid
        • Markdown Use
        • webview白屏的问题查找和修复
        • 前端开发对接问题和解决办法汇总
        • 国务院机构改革方案
        • 国家级智库
        • 实用网站推荐
        • 常用Markdown数学公式语法
        • 强烈推荐前端要安装的vscode扩展
        • 新建销售计划-页面卡死问题分析
        • 海淘入坑手册
        • 竞品研究
        • 足球知识速成
      • Git
        • GitBook安装和常用命令
        • GitKraken免费版本
        • Git安装和配置
        • Git异常处理
        • Git Worktree使用
        • 前端工程化相关的实用git命令
      • JS
        • ESM模块导出方式对比
        • Emoji多端统一处理
        • JS发布订阅模式
        • JS性能优化
        • JS标准内置对象
        • JS链式调用原理
        • Promise介绍和使用
        • Range的使用
        • Vue+Oauth登录实现
        • Vue实现富文本插入Emoji
        • chrome扩展入门
        • es5新特性
        • es6常用特性
        • es常用片段
        • uniapp使用eslint校验代码
        • 与移动端通信
        • 优秀js库moment
        • 使用vue-socketio
        • 实现一个中间件
        • 小程序webview调试
        • 常用snippets
        • 常用正则
        • 常用的设计模式
        • 微信jssdk封装使用
        • 浏览器宏任务和微任务
        • 浏览器的5种Observer
        • 深入理解赋值、浅拷贝、深拷贝
        • 解析vue指令clickoutside源码
        • 键盘事件与KeyBoardWrapper交互
        • 高德地图常用方法封装
        • 高阶函数片段
      • Network
        • 使用Lighthouse分析前端性能
        • 前后端启用https
        • 宝塔nginx安装ngx_brotli
        • 比较gz与br加载速度
        • 浏览器https提示不安全
        • 浏览器提示HSTS
        • 简单使用tcpdump
        • 静态资源gzip优化
      • Node
        • CommonJS模块导出方式对比
        • Taro command not found 多平台解决方案
        • koa使用和API实现
        • node安装报错Unexpected-token
        • 使用nvm和nrm
        • 使用uniapp给小程序添加云函数
        • 使用verdaccio搭建本地npm仓库
        • 使用vue-cli搭建vue项目
        • 安装Node.js和npm配置
        • 编译成cjs和mjs的思路解析
        • 让你的npmPackage同时支持cjs和mjs
        • 通过GithubAction将内容部署到vps
      • Python
        • Python源管理
        • Python版本管理
        • mitmproxy抓包
        • 微信公众平台开发爬坑经历
      • Shell
        • Ubuntu安装deepin桌面环境
        • Ubuntu安装flatpak软件
        • Ubuntu安装wireshark
        • Ubuntu常见问题汇总
        • dell G3装系统无法识别第二块硬盘
        • linux下virtualbox用gho还原系统
        • mysql常用命令
        • navicat连接一键集成环境的mysql
        • nginx常用命令
        • pm2常用命令
        • virtualbox虚拟机和宿主机互相复制粘贴
        • vps内资源通过mega快传到本地
        • vps报错temporary failure in name resolution
        • vscode修改文件监控数
        • windows+linux双系统引导修复
        • zsh常用插件和命令
        • 一键搭建ChatGPT web版
        • 使用V2ray,CloudFlare Warp解锁GPT
        • 使用vscode进行java开发
        • 利用zx和SSHKey发布代码到服务器
        • 反爬虫一些方案总结和尝试
        • 安装1Panel
        • 安装Bt面板
        • 安装Ubuntu22.04后要做的事
        • 无显示器linux设置默认分辨率
        • 特别实用的shell命令
        • 解决linux安装xmind缺少依赖报错
      • Standards
        • CSS格式化之stylelint
        • CSS规范
        • HTML规范
        • JS规范
        • commit规范
        • 使用husky+commitlint规范代码提交
        • 使用semantic-release自动管理版本号
        • 命名规范
        • 图片规范
        • 版本编号规范
      • Wall
        • 科学上网-Cloudflare-Pages
        • 科学上网-Cloudflare-Warp
        • 科学上网-Geph
        • 科学上网-RackNerd
        • 科学上网-Slicehosting
        • 科学上网-Surfshark
        • 科学上网-Tor
        • 科学上网-XX-NET
        • 科学上网-heroku
        • 科学上网-shadowsock
        • 科学上网-v2ray使用
        • 科学上网-v2ray搭建
        • 科学上网-浏览器代理
        • 科学上网-让终端走代理
      • Windows
        • SourceTree破解免登录(windows版)
        • git bash交互提示符不工作
        • nexus 7 2013 wifi 刷机
        • tree命令生成文件目录
        • 利用charles抓包app
        • 安装Openssl
        • 安装msi文件报错2503和2502
        • 神器vimium使用说明
        • 自用host
        • 解决win10扩展出来的屏幕模糊
        • 解决安装Adobe Air时发生错误
    • Snippets
      • zsh
        • docker
        • extract
        • git-commit
        • git
        • mysql-macports
        • npm
        • nvm
        • pip
        • pm2
        • systemd
        • ubuntu
        • vscode
Powered by GitBook
On this page
  • 背景
  • 添加路径
  • vue模板
  • uniVue模板
  • component
  • api.js
  • request
  • initStorage
  • judgeAll
  • setStorage
  • image
  • staticHostImg
  • formatDate
  • initSelections
  • iconfont
  • initLinkAndTitle
  • onShow
  • getParams
  • goto
  • getPrePage
  • getList
  • uniUpload
  • promise

Was this helpful?

  1. Docs
  2. Articles
  3. JS

常用snippets

背景

基于 vscode ,提高开发效率

添加路径

File >> Preferences >> User Snippets >> New Snippets

vue模板

{
  // Place your snippets for vue here. Each snippet is defined under a snippet name and has a prefix, body and 
  // description. The prefix is what is used to trigger the snippet and the body will be expanded and inserted. Possible variables are:
  // $1, $2 for tab stops, $0 for the final cursor position, and ${1:label}, ${2:another} for placeholders. Placeholders with the 
  // same ids are connected.
  // Example:
  // "Print to console": {
  // 	"prefix": "log",
  // 	"body": [
  // 		"console.log('$1');",
  // 		"$2"
  // 	],
  // 	"description": "Log output to console"
  // }
  "vue": {
    "prefix": "vue",
    "body": [
      "<template>",
        "  <view class=\"container\">",
        "  </view>",
      "</template>",
      "",
      "<script>",
      "import { config, util, api } from '../../utils/index'",
      "export default {",
        "  components: {},",
        "  computed: {",
        "    // test: {",
        "    //   get: function () {},",
        "    //   set: function (v) {}",
        "    // }",
        "  },",
        "  watch: {",
        "    // test: function (newObj, oldObj) {}",
        "  },",
        "  data () {",
          "    return {",
            "      staticHost: config.staticHost,",
            "      defaultImg: config.defaultImg,",
            "      assets: config.defaultImg.assets,",
            "      dataList: [],",
            "      resData: {},",
            "      dataLoading: false",
          "    }",
        "  },",
        "  beforeCreate () {},",
        "  created () {},",
        "  beforeMount () {},",
        "  mounted () {},",
        "  beforeDestroy () {},",
        "  destroyed () {},",
        "  onLoad (op) {},",
        "  onShow () {},",
        "  onReady () {},",
        "  // 用户点击右上角分享",
        "  onShareAppMessage: function (res) {",
          "    const that = this",
          "    if (res.from === 'button') {",
            "      const shareMsg = util.getShareObj(that)",
            "      return util.commonShareAppMessage(shareMsg)",
          "    } else {",
            "      return util.commonShareAppMessage()",
          "    }",
        "  },",
        "  onPullDownRefresh () {},",
        "  onReachBottom () {},",
        "  methods: {}",
      "}",
      "</script>",
      "",
      "<style lang='scss' scoped>",
      ".container {",
        "  background: #f7f8fa;",
      "}",
      "</style>",
      "",
    ]
  }
}

uniVue模板

{
  // Place your global snippets here. Each snippet is defined under a snippet name and has a scope, prefix, body and 
  // description. Add comma separated ids of the languages where the snippet is applicable in the scope field. If scope 
  // is left empty or omitted, the snippet gets applied to all languages. The prefix is what is 
  // used to trigger the snippet and the body will be expanded and inserted. Possible variables are: 
  // $1, $2 for tab stops, $0 for the final cursor position, and ${1:label}, ${2:another} for placeholders. 
  // Placeholders with the same ids are connected.
  // Example:
  // "Print to console": {
  // 	"scope": "javascript,typescript",
  // 	"prefix": "log",
  // 	"body": [
  // 		"console.log('$1');",
  // 		"$2"
  // 	],
  // 	"description": "Log output to console"
  // }
  "uni": {
    "prefix": "uni",
    "body": [
      "<template>",
        "  <view class=\"container\">",
        "  </view>",
      "</template>",
      "",
      "<script>",
      "import { config, util, api } from '../../utils/index'",
      "export default {",
        "  components: {},",
        "  computed: {",
        "    // test: {",
        "    //   get: function () {},",
        "    //   set: function (v) {}",
        "    // }",
        "  },",
        "  watch: {",
        "    // test: function (newObj, oldObj) {}",
        "  },",
        "  data () {",
          "    return {",
            "      staticHost: config.staticHost,",
            "      defaultImg: config.defaultImg,",
            "      assets: config.defaultImg.assets,",
            "      dataList: [],",
            "      resData: {},",
            "      dataLoading: false",
          "    }",
        "  },",
        "  onLoad (op) {},",
        "  onShow () {},",
        "  onReady () {},",
        "  onHide () {},",
        "  onUnload () {},",
        "  onResize () {},",
        "  onPullDownRefresh () {},",
        "  onReachBottom () {},",
        "  onShareAppMessage: function (res) {",
          "    const that = this",
          "    if (res.from === 'button') {",
            "      const shareMsg = util.getShareObj(that)",
            "      return util.commonShareAppMessage(shareMsg)",
          "    } else {",
            "      return util.commonShareAppMessage()",
          "    }",
        "  },",
        "  onPageScroll (e) {},",
        "  methods: {}",
      "}",
      "</script>",
      "",
      "<style lang='scss' scoped>",
      ".container {",
        "  background: #f7f8fa;",
      "}",
      "</style>",
      "",
    ]
  }
}

component

{
  "component": {
    "prefix": "component",
    "body": [
      "<template>",
        "  <view class=\"component\">",
        "  </view>",
      "</template>",
      "",
      "<script>",
      "import { config } from '../../../utils/index'",
      "export default {",
        "  props: {",
        "    isFixed: {",
        "      type: Boolean,",
        "      default: false",
        "    }",
        "  },",
        "  components: {},",
        "  computed: {",
        "    // test: {",
        "    //   get: function () {},",
        "    //   set: function (v) {}",
        "    // }",
        "  },",
        "  watch: {",
        "    // test: function (newObj, oldObj) {}",
        "  },",
        "  data () {",
          "    return {",
            "      staticHost: config.staticHost,",
            "      defaultImg: config.defaultImg,",
            "      assets: config.defaultImg.assets",
          "    }",
        "  },",
        "  beforeCreate () {},",
        "  created () {},",
        "  beforeMount () {},",
        "  mounted () {},",
        "  beforeUpdate () {},",
        "  updated () {},",
        "  beforeDestroy () {},",
        "  destroyed () {},",
        "  methods: {}",
      "}",
      "</script>",
      "",
      "<style lang='scss'>",
      ".component {}",
      "</style>",
      "",
    ]
  }
}

api.js

{
  "api": {
    "prefix": "api",
    "body": [
      "const config = require('../config.js')",
      "module.exports = {",
      "  getList: config.host + 'api/' // xxx",
      "}",
      "",
    ]
  }
}

request

{
  "request": {
    "prefix": "request",
    "body": [
      "const that = this",
      "const url = api.getChatConversation",
      "const params = {}",
      "const transHeader = { Authorization: this.loginTokenInfo.token }",
      "uni.showLoading()",
      "util.postData.call(this, url, params, 'POST', function (res) {",
      "  if (res.data) {",
      "    const data = res.data.data",
      "    const tips = '保存成功'",
      "    uni.showToast({ title: tips, icon: 'none', duration: 1500 })",
      "  }",
      "  uni.hideLoading()",
      "}, function (err) {",
      "  uni.hideLoading()",
      "  uni.showToast({ title: err.data.msg, icon: 'none', duration: 1500 })",
      "}, transHeader)",
    ]
  }
}

initStorage

{
  "initStorage": {
    "prefix": "initStorage",
    "body": [
      "initStorage () {",
      "  const loginUserInfo = xtyStorage.get(xtyStorage.loginUserInfo)",
      "  this.loginUserInfo = loginUserInfo ? JSON.parse(loginUserInfo) : {}",
      "}",
    ]
  }
}

judgeAll

{
  "judgeAll": {
    "prefix": "judgeAll",
    "body": [
      "judgeAll () {",
      "  let sum = 1",
      "  let msg = ''",
      "  if (this.userName) {",
      "    sum *= 1",
      "  } else {",
      "    msg = '昵称不能为空'",
      "    sum *= 0",
      "  }",
      "  if (msg) {",
      "    uni.showToast({ title: msg, icon: 'none', duration: 1500 })",
      "  }",
      "  return sum",
      "}",
    ]
  }
}

setStorage

{
  "setStorage": {
    "prefix": "setStorage",
    "body": [
      "const info = {}",
      "xtyStorage.set(xtyStorage.loginTokenInfo, JSON.stringify(info))",
    ]
  }
}

image

{
  "image": {
    "prefix": "image",
    "body": [
      "<image class=\"tips tip-1\" :mode=\"'scaleToFill'\" :src=\"assets.customer_chat\" @error=\"imageError\"></image>",
    ]
  }
}

staticHostImg

{
  "staticHostImg": {
    "prefix": "staticHostImg",
    "body": [
      "item.productImg = `${config.staticHost}${item.productImg}`",
    ]
  }
}

formatDate

{
  "formatDate": {
    "prefix": "formatDate",
    "body": [
      "item.endTime = util.formatDate(new Date(Number(item.endTime)), 'yyyy-MM-dd hh:mm')",
    ]
  }
}

initSelections

{
  "initSelections": {
    "prefix": "initSelections",
    "body": [
      "initSelections () {",
      "  this.operList = selectOptions.exchangeGoodsDetailOptions1",
      "}",
    ]
  }
}

iconfont

{
  "iconfont": {
    "prefix": "iconfont",
    "body": [
      "<text class=\"iconfont icon-fanhui1\"></text>",
      "<text class=\"inline t-icon hxjs-iconxuanzhong\"></text>",
    ]
  }
}

initLinkAndTitle

{
  "initLinkAndTitle": {
    "prefix": "initLinkAndTitle",
    "body": [
      "initLinkAndTitle () {",
      "  const { bitmap } = config.InviteMessage",
      "  const referralLink = `/pages/invite/register?invitationCode=${this.resData.invitationCode}`",
      "  this.shareObj = {",
      "    title: this.resData.subTitle,",
      "    image: bitmap,",
      "    pageLink: referralLink",
      "  }",
      "}",
    ]
  }
}

onShow

{
  "onShow": {
    "prefix": "onShow",
    "body": [
      "onShow () {",
      "  const currPage = util.getCurrentPage()",
      "  if (currPage.data.distributeId) {",
      "    this.distributeId = currPage.data.distributeId",
      "  }",
      "},",
    ]
  }
}

getParams

{
  "getParams": {
    "prefix": "getParams",
    "body": [
      "getParams () {",
      "  const params = {}",
      "  return params",
      "},",
    ]
  }
}

goto

{
  "goto": {
    "prefix": "goto",
    "body": [
      "// 1:关闭当前页面,跳转到应用内的某个页面",
      "// 2:跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面 需在 app.json 的 tabBar 字段定义的页面  路径后不能带参数",
      "// 3:关闭所有页面,打开到应用内的某个页面",
      "// 99:关闭当前页面,返回上一页面或多级页面",
      "// default:保留当前页面,跳转到应用内的某个页面",
      "util.commonViewTap('/pages/shop/searchResult')",
    ]
  }
}

getPrePage

{
  "getPrePage": {
    "prefix": "getPrePage",
    "body": [
      "const prePage = util.getPrePage()",
      "// #ifndef H5",
      "prePage.setData({",
      "  isReRender: true",
      "})",
      "util.returnPrevPage()",
      "// #endif",
    ]
  }
}

getList

{
  "getList": {
    "prefix": "getList",
    "body": [
      "dataList: [],",
      "hasMore: true,",
      "page: 1,",
      "limit: 10,",
      "getParams () {",
      "  const params = {}",
      "  return params",
      "},",
      "getList () {",
      "  const that = this",
      "  const url = api.getSearchShopList",
      "  const params = this.getParams()",
      "  uni.showLoading()",
      "  util.postData.call(this, url, params, 'POST', function (res) {",
      "    if (res.data) {",
      "      const data = res.data.data",
      "      that.totalPage = data.pages",
      "      that.hasMore = that.page < data.pages",
      "      // that.dataList = that.dealDataList(data)",
      "      uni.hideLoading()",
      "    }",
      "  }, function (err) {",
      "    uni.hideLoading()",
      "    uni.showToast({ title: err.data.msg, icon: 'none', duration: 1500 })",
      "  })",
      "},",
      "getNextPage () {",
      "  const that = this",
      "  const url = api.getSearchShopList",
      "  if (this.page >= this.totalPage) {",
      "    return false",
      "  }",
      "  this.page += 1",
      "  const params = this.getParams()",
      "  uni.showLoading()",
      "  util.postData.call(this, url, params, 'POST', function (res) {",
      "    if (res.data) {",
      "      const data = res.data.data",
      "      that.totalPage = data.pages",
      "      that.hasMore = that.page < data.pages",
      "      // that.dataList = [...that.dataList, ...that.dealDataList(data)]",
      "      uni.hideLoading()",
      "    }",
      "  }, function (err) {",
      "    uni.hideLoading()",
      "    uni.showToast({ title: err.errMsg, icon: 'none', duration: 1500 })",
      "  })",
      "},",
    ]
  }
}

uniUpload

{
  "uniUpload": {
    "prefix": "uniUpload",
    "body": [
      "const transHeader = { Authorization: this.loginTokenInfo.token }",
      "const apiUrl = api.idCardGetInfo",
      "const imgUrl = subThis.formObj.frontImg",
      "util.uniUpload((res) => {",
      "  // do something",
      "  subThis.deal(res)",
      "}, (err) => {",
      "  uni.showToast({ title: err.data.msg, icon: 'none', duration: 1500 })",
      "}, apiUrl, imgUrl, {}, config.idCardUploadRequestBehindLabel, transHeader)",
    ]
  }
}

promise

{
  "promise": {
    "prefix": "promise",
    "body": [
      "const p1 = new Promise(function (resolve, reject) {",
      "  const that = this",
      "  const url = api.getChatConversation",
      "  const params = {}",
      "  const transHeader = { Authorization: that.loginTokenInfo.token }",
      "  uni.showLoading()",
      "  util.postData.call(this, url, params, 'POST', function (res) {",
      "    if (res.data) {",
      "      const data = res.data.data",
      "      const tips = '保存成功'",
      "      uni.showToast({ title: tips, icon: 'none', duration: 1500 })",
      "    }",
      "    uni.hideLoading()",
      "  }, function (err) {",
      "    uni.hideLoading()",
      "    uni.showToast({ title: err.data.msg, icon: 'none', duration: 1500 })",
      "  }, transHeader)",
      "})",
      "Promise.all([p1]).then(res => {",
      "  // do something",
      "})",
    ]
  }
}
Previous小程序webview调试Next常用正则

Last updated 11 months ago

Was this helpful?