存储与运行JavaScript函数

一、背景介绍

如上图所示,有一个列表设置按钮,点击弹窗,可以对列表的表头顺序等进行设置,点击保存后则将最新的列表转化为字符串传给后端,以下代码则是表头的部分,在进入页面的时候发起请求得到传入的那个字符串,在将其转化为数组,进行列表的渲染。

yaml 复制代码
[
  {  prop: 'suggestState', label: '评估状态', width: 130,  isEditItem: true, controlType: 'select', showBatch: true, options: [ { value: 1, label: '已评估' }, { value: 0, label: '未评估' } ], formatter: row => row.suggestState === 1 ? '已评估' : '未评估', whetherIcon: false, },
  {  prop: 'suggest', label: '评估意见', minWidth: 150, isEditItem: true, controlType: 'input' },
]

二、问题来了

基于以上背景我们会发现,在我们的表头数组中会存在formatter对应的函数,可是当我们使用JSON.stringify来转化数组的时候遇到函数则会被忽略或者为null那么我们该如何实现将JavaScript中的函数转化为字符串并且存储到服务器上有必要时,获取然后再转化回来进行使用呢

三、解决思路

既然直接使用JSON.stringify会忽略函数,我们可以采用toString将函数转化为字符串,因为这个可以梳理思路:

  1. 先将对象中的函数进行toString操作,formatter: (function rowSet(){ return row.suggestState === 1 ? '已评估' : '未评估'}).toString()
  2. 再使用JSON.stringify把数组转化为字符串,这样就实现了将完整的数据保存到服务器上
  3. 接下来就是从服务器上将字符串拿出来了,通过使用JSON.parse来解析之前的字符串得到的数组,但是formatter后对应的是"function rowSet (row) {\n return row.suggestState === 1 ? '已评估' : '未评估';\n }"字符串了,不是函数了,
  4. 接下来我们将要对这个字符串函数进行转化,由于是数组,我们就得去确定是哪些元素是具有函数的因此可以封装如下函数:
javascript 复制代码
function restoreFunctionsInArray(arr) {
    return arr.map(obj => {
        for (const key in obj) { 
            if (typeof obj[key] === 'string' && obj[key].includes('function')) { 
                obj[key] = new Function('return ' + obj[key])();
            } 
        }
        return obj; 
    });
 }

这种写法仅限于你声明函数的方式是函数式声明,也就是function加函数名的方式声明的函数,代码的大致含义就是,但检查到数组的某个元素的某个键值对的值是字符串,并且字符串含有function字段,则采用 new Function 的方式将那个字符串传入其中并且通过return的方式确保这个字符串可以有一个返回值,这样就将刚才是字符串的函数替换成了函数。

四、使用封装的类库

一个问题的产生,如果背后是一个工程化问题的话,一般情况下你都能够找到对应的通用解决方案,因此也找到了一个解决方案, xijs 由于本人没有使用过,因此此方案请自行尝试,如有问题自行负责。

相关推荐
哆啦A梦158815 分钟前
Vue3魔法手册 作者 张天禹 08_回顾TS中的-接口-泛型-自定义事件
前端·vue.js·typescript
星火开发设计21 分钟前
序列式容器:list 双向链表的特性与用法
开发语言·前端·数据结构·数据库·c++·链表·list
014-code27 分钟前
ESLint 详解
前端·eslint
GISer_Jing38 分钟前
前端营销I(From AIGC)
前端·aigc·ai编程
明月_清风1 小时前
向 Native 借力:深度拆解 SIMD 加速与 Node.js 异步原生解析
前端·json
明月_清风1 小时前
无感监控:深度拆解监控 SDK 的性能平衡术与调度策略
前端·监控
键盘鼓手苏苏3 小时前
Flutter for OpenHarmony:markdown 纯 Dart 解析引擎(将文本转化为结构化 HTML/UI) 深度解析与鸿蒙适配指南
前端·网络·算法·flutter·ui·html·harmonyos
芭拉拉小魔仙9 小时前
企业级Vue项目的状态管理:从原理到实战架构
前端·vue.js·架构
恋猫de小郭9 小时前
丰田正在使用 Flutter 开发游戏引擎 Fluorite
android·前端·flutter
扶苏100210 小时前
Vue 3 响应式原理深度解析
前端·javascript·vue.js