javascript ,从mozilla 官方网站学习语法,非常不错_org.mozilla.javascript-程序员宅基地

技术标签: foreach  nodejs  javascript  

本文的原文连接是:
https://blog.csdn.net/freewebsys/article/details/81153733

博主地址是:http://blog.csdn.net/freewebsys

1,关于mozilla 开发者


https://developer.mozilla.org/zh-CN/
还有这么一个开发者中心呢,上面搜索写JavaScript的东西也相当的全面。
开始是使用 firefox,现在使用了 chrome就再也不看 mozilla 的东西了。
但是人家有个号东西也去学习。
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Guide/Introduction
学习javascript

2,学习


虽然写javascript好多年,但是一些高级的用法不会。
造成代码感觉上冗余的多,不优美。
比如昨天写的CURD 项目设置属性为空,就相当难看的代码:

filters: {
          id: '',
          userName: '',
          password: '',
          nickName: '',
          role: '',
          status: '',
          type: '',
        },
        loading: false,
        dataForm: {
    //编辑界面数据
          id: '',
          userName: '',
          password: '',
          nickName: '',
          role: '',
          status: '',
          type: '',
          createTime: '',
          updateTime: '',
        },

感觉上肯定有啥高级的用法,能将属性的默认值设置空啥的。
或者使用啥foreach的函数。

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/keys

拼接字符串:

let tmpDataForm = this.dataForm //赋值变量
          Object.keys(tmpDataForm).forEach(function(key){
    
            data += "&"+key+"=" + tmpDataForm[key]
          })
进行filter查询:
let query = ""
        let tmpFilters = this.filters //赋值变量
        Object.keys(tmpFilters).forEach(function(key){
    
          query += "&"+key+"=" + tmpFilters[key]
        })

3,代码优化


昨天的curd优化:
https://blog.csdn.net/freewebsys/article/details/81112630

<template>
 <section>

  <!--工具条-->
  <el-col :span="24" class="toolbar" style="padding-bottom: 0px;">
   <el-form :inline="true" :model="filters">
    <el-form-item><el-button type="primary" @click="editFunc">新建</el-button></el-form-item>
    <el-form-item><el-input v-model="filters.id" placeholder="id"></el-input></el-form-item>
    <el-form-item><el-input v-model="filters.userName" placeholder="用户名"></el-input></el-form-item>
    <el-form-item><el-input v-model="filters.password" placeholder="密码"></el-input></el-form-item>
    <el-form-item><el-input v-model="filters.nickName" placeholder="昵称"></el-input></el-form-item>
    <el-form-item><el-input v-model="filters.role" placeholder="角色"></el-input></el-form-item>
    <el-form-item><el-input v-model="filters.status" placeholder="状态"></el-input></el-form-item>
    <el-form-item><el-input v-model="filters.type" placeholder="类型"></el-input></el-form-item>
    <el-form-item>
     <el-button type="primary" v-on:click="listFunc">查询</el-button>
    </el-form-item>
   </el-form>
  </el-col>

  <!--列表-->
  <template>
   <el-table :data="dataList" v-loading="loading" style="width: 100%;">

    <el-table-column prop="id" label="id"/>
    <el-table-column prop="userName" label="用户名"/>
    <el-table-column prop="password" label="密码"/>
    <el-table-column prop="nickName" label="昵称"/>
    <el-table-column prop="role" label="角色"/>
    <el-table-column prop="status" label="状态"/>
    <el-table-column prop="type" label="类型"/>
    <el-table-column prop="createTime" label="创建时间"/>
    <el-table-column prop="updateTime" label="更新时间"/>
    <el-table-column label="操作" width="150">
     <template slot-scope="scope"><el-button-group>
      <el-button type="primary" size="mini" @click="editFunc(scope.$index, scope.row)">编辑</el-button>
      <el-button type="danger" size="mini" @click="deleteFunc(scope.$index, scope.row)">删除</el-button>
      </el-button-group></template>
    </el-table-column>
   </el-table>
  </template>
  <el-col style="text-align:right;padding-top: 30px;">
   <el-pagination @current-change="pageChangeFunc" background="" layout="prev, pager, next" :total="totalCount">
   </el-pagination>
  </el-col>

  <!--编辑弹出页面-->
  <el-dialog title="用户编辑" :visible.sync="dialogVisible">
   <el-input v-model="dataForm.id" placeholder="id" type="hidden"/>
   <el-form label-width="100px" :rules="dataFormRules" ref="dataForm">
    <el-form-item label="用户名" prop="userName"><el-input/></el-form-item>
    <el-form-item label="密码" prop="password"><el-input/></el-form-item>
    <el-form-item label="昵称" prop="nickName"><el-input v-model="dataForm.nickName"/></el-form-item>
    <el-form-item label="角色" prop="role"><el-input v-model="dataForm.role"/></el-form-item>
    <el-form-item label="状态" prop="status"><el-input v-model="dataForm.status"/></el-form-item>
    <el-form-item label="类型" prop="type"><el-input v-model="dataForm.type"/></el-form-item>
   </el-form>
   <span slot="footer" class="dialog-footer">
      <el-button @click="dialogVisible = false">取 消</el-button>
      <el-button type="primary" @click="saveFunc">确 定</el-button>
    </span>
  </el-dialog>

 </section>
</template>

<script>
export default {
    data() {
      return {
        filters: {
          id: '', userName: '', password: '', nickName: '', role: '', status: '', type: '',
        },
        loading: false,
        dataForm: {
    //编辑界面数据
          id: '', userName: '', password: '', nickName: '', role: '', status: '', type: '', createTime: '', updateTime: '',
        },
        dataFormRules: {
    //编辑界面校验规则
          userName: [{required: true, message: '请输入用户名', trigger: 'blur' } ],
          password: [{required: true, message: '请输入密码', trigger: 'blur' } ],
          nickName: [{required: true, message: '请输入昵称', trigger: 'blur' } ],
          role: [{required: true, message: '请输入角色', trigger: 'blur' } ],
          status: [{required: true, message: '请输入状态', trigger: 'blur' } ],
          type: [{required: true, message: '请输入类型', trigger: 'blur' } ],
        },
        dialogVisible: false,
        dataList: [], //列表数据
        totalCount: 0,
        currentPage: 1
      }
    },
    methods: {
      editFunc: function(index, row) {
     //新建&编辑
        if (row == undefined) {
          let tmpDataForm = this.dataForm //赋值变量,修改tmpDataForm即可
          Object.keys(tmpDataForm).forEach(function(key){
     
            tmpDataForm[key] = ''
          })
          this.dialogVisible = true
        } else {
          this.$axios.get('/userInfo/get?id=' + row.id)
          .then(resp => {
    //数据直接赋值
              this.dataForm = resp.data.data
            }).finally(() => {
            this.loading = false
            this.dialogVisible = true
          })
      }},
      saveFunc: function() {
     
        this.$refs['dataForm'].validate((valid) => {
          if (!valid) { return false }
          let data = ""
          let tmpDataForm = this.dataForm //赋值变量
          Object.keys(tmpDataForm).forEach(function(key){
     
            data += "&"+key+"=" + tmpDataForm[key]
          })
          this.$axios.post('/userInfo/save?' + data)
          .finally(() => {
            this.dialogVisible = false
            this.listFunc()
          })
        })
      },
      deleteFunc: function(index, row) {
     
        this.$confirm('确认删除该记录吗?', '提示', {
          type: 'warning'
        }).then(() => {
          this.$axios.delete('/userInfo/delete?id=' + row.id)
          .finally(() => {
            this.listFunc()
          })
        })
      },
      listFunc: function() {
     
        this.loading = true
        let query = ""
        let tmpFilters = this.filters //赋值变量
        Object.keys(tmpFilters).forEach(function(key){
     
          query += "&"+key+"=" + tmpFilters[key]
        })
        this.$axios.get('/userInfo/list?page=' + this.currentPage + query)
        .then(resp => {
          this.dataList = resp.data.data
          this.totalCount = resp.data.totalCount
        }).finally(() => {
          this.loading = false
        })
      },
      pageChangeFunc: function(idx) {
     
        this.currentPage = idx
        this.listFunc()
      }
    },
    created: function() {
     
      this.listFunc()
    }
  };
</script>

4,总结


js代码中出现大量的 set 代码其实是冗余的本来就是动态语言,不能像java那样去写:this.xxx = xxx 这样不优雅。
要用 forEach去写:

let tmpDataForm = this.dataForm //赋值变量,修改tmpDataForm即可
          Object.keys(tmpDataForm).forEach(function(key){
    
            tmpDataForm[key] = ''
          })

这个要是大表单数据,十几个 也没有啥意义。

本文的原文连接是:
https://blog.csdn.net/freewebsys/article/details/81153733

博主地址是:http://blog.csdn.net/freewebsys

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/freewebsys/article/details/81153733

智能推荐

蓝凌EIS智慧协同平台saveImg接口存在任意文件上传漏洞_蓝凌eis智慧协同平台文件上传漏洞-程序员宅基地

文章浏览阅读979次。蓝凌智慧协同平台eis集合了非常丰富的模块,满足组织企业在知识、协同、项目管理系统建设等需求。_蓝凌eis智慧协同平台文件上传漏洞

LLaVA-1.5-程序员宅基地

文章浏览阅读193次。与InstructBLIP或Qwen-VL在数亿甚至数十几亿的图像文本配对数据上训练的、专门设计的视觉重新采样器相比,LLaVA用的是最简单的LMM架构设计,只需要在600K个图像-文本对上,训练一个简单的完全连接映射层即可。结果表明,LLaVA-1.5不仅可以使用更少的预训练和指令微调数据,而且还可以利用最简单的架构、学术计算和公共数据集来实现最佳的性能——在12个基准中的11个上取得了SOTA。为了解决这个问题,研究人员建议在VQA问题的末尾,添加一个可以明确输出格式的提示,进而让模型生成简短回答。

ORACLE基本数据类型总结_oracle 数值类型最大值-程序员宅基地

文章浏览阅读442次。2013-08-17 21:04 by 潇湘隐者, 100246 阅读, 5 评论, 收藏, 编辑 ORACLE基本数据类型(亦叫内置数据类型 built-in datatypes)可以按类型分为:字符串类型、数字类型、日期类型、LOB类型、LONG RAW& RAW类型、ROWID & UROWID类型。在讲叙字符串类型前,先要讲一下编码。字符串类型的数据可依编码方式分成_oracle 数值类型最大值

10种机器学习算法_决策树和mlp-程序员宅基地

文章浏览阅读315次。作为数据科学家的实践者,我们必须了解一些通用机器学习的基础知识算法,这将帮助我们解决所遇到的新领域问题。本文对通用机器学习算法进行了简要的阐述,并列举了它们的相关资源,从而帮助你能够快速掌握其中的奥妙。▌1.主成分分析(PCA)/ SVDPCA是一种无监督的方法,用于对由向量组成的数据集的全局属性进行理解。本文分析了数据点的协方差矩阵,以了解哪些维度(大部分情况)/数据点(少数情况)更为重要,即它..._决策树和mlp

桥接模式的实现-程序员宅基地

文章浏览阅读148次。在这个示例中,我们使用std::shared_ptr来管理Implementor对象的生命周期,确保在不再需要时自动释放资源。通过智能指针的使用,我们避免了手动管理内存的复杂性,提高了代码的可靠性和可维护性。希望这个示例能帮助你理解如何使用智能指针来实现桥接模式。当使用智能指针来实现桥接模式时,我们可以利用std::shared_ptr或std::unique_ptr来管理对象的生命周期,确保资源的正确释放。

制造业敏感文件外发不安全?一招解锁更高效的加密方式!-程序员宅基地

文章浏览阅读440次,点赞11次,收藏8次。云盒子在制造业上有丰富的部署经验,在面向制造类企业的重要文件,可以通过审计、授权、文件加密进行多重保护,使得图纸文件、专利技术、采购订单等敏感数据等到有效保护,做到无处可泄,同时安全可靠,也不会对日常工作效率有影响 ,实现真正有效的企业文件保护的目的,达到既防止机密文件外泄和扩散,又支持内部知识积累和文件共享的目的。云盒子的加密方式是通过将本地文件数据上传到云盘进行统一加密存储,而不是对设备加密,通过【本地加密】+【云加密】双重组合下,不管用什么设备打开文件都受到管控,使管理者管理起来能够更高效。

随便推点

计算几何讲义——计算几何中的欧拉定理-程序员宅基地

文章浏览阅读188次。在处理计算几何的问题中,有时候我们会将其看成图论中的graph图,结合我们在图论中学习过的欧拉定理,我们可以通过图形的节点数(v)和边数(e)得到不是那么好求的面数f。 平面图中的欧拉定理: 定理:设G为任意的连通的平面图,则v-e+f=2,v是G的顶点数,e是G的边数,f是G的面数。证明:其实有点类似几何学中的欧拉公式的证明方法,这里采用归纳证明的方法。对m..._怎么证明平面图欧拉定理

c语言中各种括号的作用,C语言中各种类型指针的特性与用法介绍-程序员宅基地

文章浏览阅读750次。C语言中各种类型指针的特性与用法介绍本文主要介绍了C语言中各种类型指针的特性与用法,有需要的朋友可以参考一下!想了解更多相关信息请持续关注我们应届毕业生考试网!指针为什么要区分类型:在同一种编译器环境下,一个指针变量所占用的内存空间是固定的。比如,在16位编译器环境 下,任何一个指针变量都只占用8个字节,并不会随所指向变量的类型而改变。虽然所有的指针都只占8个字节,但不同类型的变量却占不同的字节数..._c语言带括号指针

缅甸文字库 缅甸语字库 缅甸字库算法_0x103c-程序员宅基地

文章浏览阅读9.5k次。字库交流 QQ:2229691219 缅甸语比较特殊、缅甸语有官方和民间之分,二者不同的是编码机制不同,因此这2种缅甸语的字串翻译、处理引擎、字库都是不同的。我们这里只讨论官方语言。 缅文、泰文等婆罗米系文字大多是元音附标文字,一般辅音字母自带默认元音可以发音,真正拼写词句时元音像标点符号一样附标在辅音上下左右的相应位置。由于每个元音位于辅音的具体位置是有自己的规则的,当只书写..._0x103c

Python+django+vue校园二手闲置物品拍卖系统pycharm毕业设计项目推荐_基于python+django+vue实现的校园二手交易平台-程序员宅基地

文章浏览阅读200次。在校园,随着学生数量的增多,存在许多生活和学习物品,许多学习用品经过一学期学习之后往往被闲置,一些出于一时喜欢而购买的物品使用机会少而被闲置,还有一些物品以低廉的价格卖给资源回收站,造成巨大的资源浪费。校园闲置物品拍卖系统使用python技术,MySQL数据库进行开发,系统后台使用django框架进行开发,具有低耦合、高内聚的特点,其中校园用户通过人脸识别的方法增加系统安全性,在闲置物品推荐中,使用协同过滤算法进行商品推荐。系统的开发,帮助高校有效的对闲置物品进行管理,提高了闲置物品销售的效率。_基于python+django+vue实现的校园二手交易平台

【推荐系统论文精读系列】(十)--Wide&Deep Learning for Recommender Systems_引用《wide & deep learning for recommender systems》-程序员宅基地

文章浏览阅读1.1k次,点赞3次,收藏3次。文章目录Wide & Deep Learning for Recommender Systems一、摘要二、介绍三、推荐系统综述四、Wide&Deep学习4.1 Wide部分4.2 Deep部分4.3 联合训练 Wide&Deep ModelPreferenceWide & Deep Learning for Recommender Systems一、摘要具有非线性特征转化能力的广义线性模型被广泛用于大规模的分类和回归问题,对于那些输入数据是极度稀疏的情况下。通过使用交_引用《wide & deep learning for recommender systems》

c++ sleep函数_Linux 多线程应用中如何编写安全的信号处理函数-程序员宅基地

文章浏览阅读171次。关于代码的可重入性,设计开发人员一般只考虑到线程安全,异步信号处理函数的安全却往往被忽略。本文首先介绍如何编写安全的异步信号处理函数;然后举例说明在多线程应用中如何构建模型让异步信号在指定的线程中以同步的方式处理。Linux 多线程应用中编写安全的信号处理函数在开发多线程应用时,开发人员一般都会考虑线程安全,会使用 pthread_mutex 去保护全局变量。如果应用中使用了信号,而且信号的产生不..._linux c++ sleep 不被中断

推荐文章

热门文章

相关标签