eval有时候也可以用,而且有奇效

eval,一个我曾经避之不及的函数,最近我对它产生了一点新的感触:eval有时候也可以用,有奇效。

一般在使用js进行开发时,是不建议使用eval这类函数的。在JavaScript中,eval可以计算传入的字符串,将其当作js代码来执行。因为它可执行js代码的特性,有可能被第三方利用,传入恶意js代码执行,因此这个函数存在安全风险。再加上eval执行的速度低于普通的js程序,因此在日常开发中,它的使用准则是“能不用就不用”、“代码中使用eval是很丑陋的一件事”。

但是这次在做拉线功能时,我“不得不”使用了它。

拉线由于数据量小,可以通过矢量渲染的方式渲染到地图上,但是通过geoserver获取的坐标数据和样式数据是分离的,且没有样式名能将二者关联起来。
样式数据里面规定每组筛选条件对应一组样式值(线段的颜色、宽度,面的颜色、透明度),以以下这段样式数据为例:

{
  "Description": {
      "Title": "hidetitle"
  },
  "Filter": {
      "And": {
          "PropertyIsGreaterThanOrEqualTo": {
              "PropertyName": "rsrp_rate",
              "Literal": "0"
          },
          "Not": {
              "PropertyIsNull": {
                  "PropertyName": "eci"
              }
          },
          "PropertyIsEqualTo": {
              "PropertyName": "geo_type",
              "Literal": "cell"
          },
          "PropertyIsLessThanOrEqualTo": {
              "PropertyName": "rk",
              "Literal": "3"
          },
          "PropertyIsLessThan": {
              "PropertyName": "rsrp_rate",
              "Literal": "0"
          }
      }
  },
  "PolygonSymbolizer": {
      "Fill": {
          "SvgParameter": [
              "#f56e3f",
              "0.15"
          ]
      },
      "Stroke": {
          "SvgParameter": [
              "#f56e3f",
              "4"
          ]
      }
  },
  "Name": "cell1-3 and rate 0-20"
},

它的涵义是:
当满足(rsrp_rate >= 0 && ect !== null && geo_type === 'cell' && rk <= 3 && rsrp_rate < 0) 的条件时,面填充颜色使用#f56e3f、透明度为0.15,线段颜色使用#f56e3f、宽度为4。

如果使用常规方式去进行拉线数据值和样式数据的计算匹配,无疑会很繁琐,执行筛选所需要的时间也会很长,这种结果无疑是“丑陋”的。但是如果使用eval,就会有奇效。

我可以先将样式数据进行处理成类似

{ operator: '>=', name: 'rsrp_rate', value: 0 }

这样的结构,并存入数组,这个数组里存放的都是and关系的筛选条件。

然后从拉线数据里获取每个指标的值indexValue,进行如下拼装:

let dataItem = { operator: '>=', name: 'rsrp_rate', value: 0 };
let filterValue = dataItem.value;
let indexValue = lineData[dataItem.name]; // 此处lineData中存储着单个拉线的指标值
eval('filterValue' + dataItem.operator + 'indexValue') ;
// 上方这行代码在编译后执行的是: filterValue >= indexValue

利用eval可以将传入的字符串当作js语句执行的特性,我就可以得到一个条件判断结果,代码相对而言也简洁很多,使用eval,反尔让代码变得优雅,大大提高了数据匹配的效率和代码的可维护性。

总之,这段开发经历,让我对eval有了新的认识。

原文链接:https://www.cnblogs.com/xsilence/p/17252805.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:eval有时候也可以用,而且有奇效 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • 每天一篇javascript学习小结(基础知识)

    作为网站的作者,推出“每天一篇javascript学习小结(基础知识)”的攻略可以让读者每天获得一些新的javascript知识,从而逐渐掌握javascript的基础知识。以下是该攻略的完整步骤: 第一步:梳理知识点 首先需要将javascript的基础知识进行梳理,将这些知识点分为相对独立的小模块,每个模块讲解内容不宜过多,建议每个知识点一篇小结。 示例…

    JavaScript 2023年5月28日
    00
  • JavaScript的removeChild()函数用法详解

    JavaScript的removeChild()函数用法详解 什么是removeChild()函数? 在JavaScript中,使用removeChild()函数可以删除指定的子节点。 removeChild()函数的用法 要使用removeChild()函数,需要先找到要删除的节点,然后将其作为参数传递给removeChild()函数。例如: var el…

    JavaScript 2023年6月10日
    00
  • 通过js获取上传的图片信息(临时保存路径,名称,大小)然后通过ajax传递给后端的方法

    获取上传的图片信息并通过ajax传递给后端,可以分为以下几个步骤: 添加文件选择控件 在HTML页面中,添加一个文件选择控件,让用户可以选择要上传的图片文件。示例代码如下: <input type="file" id="file-input"> 监听文件选择事件 使用JavaScript监听文件选择控件的c…

    JavaScript 2023年6月11日
    00
  • Js+Dhtml:WEB程序员简易开发工具包(预先体验版)

    “Js+Dhtml:WEB程序员简易开发工具包(预先体验版)”使用攻略 1. 概述 “Js+Dhtml:WEB程序员简易开发工具包(预先体验版)”是一款方便程序员快速开发WEB项目的工具包。该工具包包含多个实用的功能,如表单验证、AJAX请求等。通过简单的配置和使用,可以大大提高WEB开发效率。 2. 安装和配置 该工具包使用的是js和dhtml技术,因此只…

    JavaScript 2023年5月27日
    00
  • javascript 玩转Date对象(实例讲解)

    Javascript 玩转 Date 对象(实例讲解) 日期和时间在 Javascript 中有着非常重要的地位,而 Date 对象则是用于处理日期和时间的核心对象。在本攻略中,我们将介绍 Date 对象的常用的方法和属性,并提供一些在实际项目中可能会用到的示例供参考。 初始化 Date 对象 在创建 Date 对象时,可以使用以下语句: var date …

    JavaScript 2023年6月10日
    00
  • JS动态添加与删除select中的Option对象(示例代码)

    下面我将详细讲解如何通过JavaScript动态地添加和删除<select>元素中的<option>元素。 1. 添加<option>元素 通过JavaScript动态地往<select>元素中添加<option>元素,可以用以下代码: // 获取<select>元素 var selec…

    JavaScript 2023年6月10日
    00
  • JavaScript获取对象key的几种方法和区别

    下面是关于“JavaScript获取对象key的几种方法和区别”的详细讲解。 1. 对象属性的基本概念 在 JavaScript 中,对象是指一个或多个属性的集合。一个属性包括一个名字和一个值,名字通常称之为属性名或 key,它可以是一个字符串或者一个 Symbol(ES6中的一种数据类型)。 我们可以通过以下方式定义一个对象: const obj = {k…

    JavaScript 2023年5月27日
    00
  • Javascript RegExp test() 方法

    JavaScript RegExp的test()方法 JavaScript的RegExp对象中的test()方法是一个布尔值,用于检查一个字符串是否匹配正则表达式。如果匹配,返回true否则false。 语法 test()方法的语法如下: .test(str) 其中,str是要检查的字符串。 示例1:使用test()检查字符串是否匹配正则表达式 const …

    JavaScript 2023年5月11日
    00
合作推广
合作推广
分享本页
返回顶部