react antd 计算公式 (+-*/)运算,回显

news2025/1/11 3:52:25

在这里插入图片描述

计算器的源码

在这里插入图片描述
在这里插入图片描述

计算器触发事件

在这里插入图片描述

源码

import { DictValueEnumObj } from '@/components/DictTag';
import { getDeptTree, getFormulaListAll, getListAll } from '@/services/Energy/Metering';

import { getListAllInfo, getDepartmentName } from '@/services/Energy/Calculation';
import { ProForm, ProFormText, ProFormTreeSelect } from '@ant-design/pro-components';
import { useIntl } from '@umijs/max';
import { Button, Cascader, Form, Modal, message, Tag } from 'antd';
import { DataNode } from 'antd/es/tree';
import React, { useEffect, useState, useRef } from 'react';
import './index.scss';
import _, { forEach } from 'lodash';
import { json } from 'express';
import Item from 'antd/es/list/Item';
export type RoleFormData = Record<string, unknown> & Partial<API.System.Role>;
let data = [];
export type RoleFormProps = {
  onCancel: (flag?: boolean, formVals?: RoleFormData) => void;
  onSubmit: (values: RoleFormData) => Promise<void>;
  open: boolean;
  values: Partial<API.System.Role>;
  menuTree: DataNode[];
  menuCheckedKeys: string[];
  statusOptions: DictValueEnumObj;
  currentRow: DictValueEnumObj;
};
let meterItemIdList: string | string[];
let operatorList: string;
let formula1List: string | string[];
let chanLiangList: any[] = [];
const RoleForm: React.FC<RoleFormProps> = (props) => {
  const [form] = Form.useForm();
  const { menuTree, menuCheckedKeys } = props;
  const [menuIds, setMenuIds] = useState<string[]>([]);
  const [treeData, setTreeData] = useState<[]>([]);
  const [treeDataString, setTreeDataString] = useState<any>([]);
  const [textData, setTextData] = useState<any>('');

  const [treeData1, setTreeData1] = useState<string[]>([]);
  const [treeData2, setTreeData2] = useState<string[]>([]);
  const [formulaBatch, setFormulaBatch] = useState<string[]>([]);
  const [meterItemIdBatch, setMeterItemIdBatch] = useState<string[]>([]);

  const [disabled, setDisabled] = useState<boolean>(true);
  const [disabled1, setDisabled1] = useState<boolean>(true);
  const [operator, setOperator] = useState<string[]>([]); //回显字典
  const [operator1, setOperator1] = useState<string>(); //回显字典
  const [operator2, setOperator2] = useState<string[]>([]); //回显字典
  const [statusTypeOptions, setStatusTypeOptions] = useState<any>([]);
  const [meterItemId, setMeterItemId] = useState<string[]>([]); //回显id

  const [meterItemIdFormula, setMeterItemIdFormula] = useState<string[]>([]); //回显id
  // const [meterItemIdFormula, setMeterItemIdFormula] = useState<string[]>([]); //回显id
  const [formula1List, setFormula1List] = useState<any>([]); //回显id
  const [meterItemIdList, setMeterItemIdList] = useState<string[]>([]); //回显id
  const [statusOptions, setStatusOptions] = useState<string[]>([]);
  const [gongshi, setGongshi] = useState<string[]>([]);
  const cascaderCatergoryRef = useRef(null);
  const displayRender = (labels: string[]) => labels[labels.length - 1];

  const [roleName, setRoleName] = useState<string[]>([]);

  // const { statusOptions } = props;
  const childFun1 = (res: any) => {
    // let children = [];
    for (let itemChilf of res.children) {
      itemChilf['label'] = itemChilf.meterName;
      itemChilf['value'] = itemChilf.id;
      itemChilf['key'] = itemChilf.id;
      itemChilf['children'] = itemChilf.tbMeterInfoVoList || [];
      childFun1(itemChilf);
    }
  };
  const childFun = (res: any) => {
    if (res.tbMeterInfoVoList != null) {
      const opts: DictValueEnumObj = {};
      for (let itemChilf of res.tbMeterInfoVoList) {
        opts[itemChilf.id] = {
          text: itemChilf.id,
          label: itemChilf.meterName,
          value: itemChilf.id,
          tbMeterInfoVoList: childFun(itemChilf),
        };
      }
      return opts;
    }
    return;
  };
  const getlistFormula = () => {
    getFormulaListAll().then((res) => {
      // console.log(res);
      if (res.code === 200) {
        const opts2: DictValueEnumObj = {};
        res.data.map((item: any) => {
          item['label'] = item.indexName;
          item['value'] = item.id;
          opts2['B' + item.id] = {
            text: item.indexName,
            label: item.indexName,
            value: 'B' + item.id,
            key: 'B' + item.id,
            idString: item.idString,
            formulaString: item.formulaString,
          };
          return opts2;
        });
        setTreeData2(opts2);
      }
    });
  };
  const operaIndexOf = (itemList: any, key: any) => {
    console.log(itemList, key);
    for (let item of itemList) {
      if (item.indexOf('+') != -1) {
        console.log(item.split(key), '+');
        data.push(item.split(key));
        operaIndexOf(item.split(key), '-');
      }
    }
  };
  const getListJianZhi = (val: number) => {
    getListAllInfo(val).then((res: any) => {
      if (res.code === 200) {
        const opts2: DictValueEnumObj = {};
        res.data.map((item: any) => {
          item['label'] = item.indexName;
          item['value'] = item.id;
          opts2['A' + item.id] = {
            text: item.bcMeterDataTypeVo?.meterType,
            label: item.bcMeterDataTypeVo?.meterType,
            value: 'A' + item.id,
            key: 'A' + item.id,
          };
          return opts2;
        });
        setTreeData1(opts2);
        // let data = res.data.map((item: any) => {
        //   item['label'] = item.bcMeterDataTypeVo?.meterType;
        //   item['value'] = 'A'+item.id;

        //   return item;
        // });
        // setTreeData1(data);
        // getlistFormula(val[val.length - 1]);
      }
    });
  };
  const getChanliang = () => {
    let data = [
      { deptId: 'C' + 101, deptName: '经典薄片车间产量' },
      { deptId: 'C' + 102, deptName: '新型薄片车间产量' },
    ];
    chanLiangList = data;
    // chanLiangList = data?.map(res=>{
    //   res.deptId = 'C' + res.deptId
    //   return res
    // });
    // getDepartmentName().then((res: { code: number; data: any[]; }) => {
    //   if (res.code === 200) {
    //     console.log(res)
    //     chanLiangList = res.data?.map(res=>{
    //       res.deptId = 'C' + res.deptId
    //       return res
    //     });
    //   }
    // })
  };
  useEffect(() => {
    getChanliang();
    form.resetFields();
    setTreeData([]);

    form.setFieldsValue({
      deptId: props.values.deptId,
      geo: props.values.geo,
      domain: props.values.domain,
      metric: props.values.metric,
      deptName: props.values.deptName,
      digitNum: props.values.digitNum,
      generateType: props.values.generateType,
      groupFlag: props.values.groupFlag,
      indexCode: props.values.indexCode,
      indexName: props.values.indexName,
      indexType: props.values.indexType,
      kpiDetailId: props.values.kpiDetailId,
      kpiFlag: props.values.kpiFlag,
      mediumId: props.values.mediumId,
      meterItemId: props.values.meterItemId,
      meteringUnitId: props.values.meteringUnitId,
      indexNo: props.values.indexNo,
      isEdit: props.values.isEdit,

      formula1: props.values.operator,
      meterItemIdBatch: props.values.meterItemIdBatch,
      formulaBatch: props.values.formulaBatch,
      operator: props.values.operator,
      id: props.values.id,
      formula: props.values.formula,
      bcEnergyMediumVoProduct: props.values.bcEnergyMediumVoProduct,
      bcMeteringUnit: props.values.bcMeteringUnit,
    });
    let operator = props.values?.operator;
    console.log(operator, form.getFieldValue(), props.currentRow);
    if (operator) {
      operator = [operator];
      operator.forEach((res: any) => {
        console.log(res, [res]?.slice('+'));
        if (res.indexOf('+') != -1) {
          // operator  = res.split('')
          console.log(operator.join(''), '+');
          operaIndexOf(operator, '+');
        }
      });
      console.log(operator);
    }
    getDeptTree().then((res: any) => {
      const exKeys = [];
      exKeys.push('1');
      // console.log(res);
      res.forEach((item: any) => {
        item['label'] = item.meterName;
        item['value'] = item.id;
        item['children'] = item.tbMeterInfoVoList || [];
        childFun1(item);
      });
      setTreeData(res);
      const opts: DictValueEnumObj = {};
      res.forEach((item: any) => {
        opts[item.id] = item;
      });
      setTreeDataString(opts);
      setTreeDataString(_.cloneDeep(opts));
    });
    getlistFormula();
    setRoleName([]);
    setOperator([]);
    // setMeterItemId([]);
    setMeterItemIdFormula([]);
    form.setFieldsValue({
      // formula: '',
      // formula1: '',
    });
    setRoleName([]);
    setOperator([]);
    setMeterItemIdFormula([]);
    // console.log(props.values.operator.split());
    setOperator2([]);
    setMeterItemId([]);
    setFormulaBatch([]);
    setMeterItemIdBatch([]);
    if (props.values.id) {
      setMeterItemIdFormula(props.values.formula.split());
      console.log(props.values.operator.split());
      setOperator2(props.values.operator.split());
      setMeterItemId(props.values.meterItemId.split());
      setFormulaBatch(props.values.formulaBatch.split());
      setMeterItemIdBatch(props.values.meterItemIdBatch.split());
      console.log(props.values, 'props', props.values?.meterItemId, formula1List);
      let zhibiao = props.values?.meterItemId?.split(/\s*(,)\s*/);
      operatorList = props.values?.operator;
      setFormula1List(props.values?.formula?.split(/\s*(\+|-|\*|\/)\s*/));
      setMeterItemIdList(props.values?.meterItemId);
      // meterItemIdList = props.values?.meterItemId;
      // formula1List = props.values?.formula
      return;
    }
  }, [form, props]);

  const intl = useIntl();
  const handleOk = () => {
    form.submit();
  };
  const handleCancel = () => {
    props.onCancel();
  };
  const handleFinish = async (values: Record<string, any>) => {
    props.onSubmit({ ...values, menuIds } as RoleFormData);
  };

  const jiData = [
    [
      { lable: '(', value: 18 },
      { lable: ')', value: 17 },
      { lable: 'AC', value: 16 },
      { lable: '/', value: 15 },
    ],
    [
      { lable: '7', value: 7 },
      { lable: '8', value: 8 },
      { lable: '9', value: 9 },
      { lable: '*', value: 14 },
    ],
    [
      { lable: '4', value: 4 },
      { lable: '5', value: 5 },
      { lable: '6', value: 6 },
      { lable: '-', value: 13 },
    ],
    [
      { lable: '1', value: 1 },
      { lable: '2', value: 2 },
      { lable: '3', value: 3 },
      { lable: '+', value: 12 },
    ],
    [
      { lable: '0', value: 0 },
      { lable: '.', value: 9 },
      { lable: '=', value: 10 },
    ],
  ];
  // 数据类型
  const getListAllType = (val: any) => {
    getListAll(val[0]).then((res: any) => {
      if (res.code === 200) {
        const opts: DictValueEnumObj = {};

        res.data.forEach((item: any) => {
          item['label'] = item.meterType;
          item['value'] = item.id;

          opts[item.id] = {
            text: item.meterType,
            label: item.meterType,
            value: item.id,
            key: item.id,
            meteringUnitId: item.meteringUnitId,
          };
        });
        // console.log(opts);
        setStatusTypeOptions(opts);
      }
    });
  };

  const dataString1 = (element: any, item: any) => {
    console.log(item, element);
    if (
      item.tbMeterInfoVoList?.length > 0 &&
      item.tbMeterInfoVoList &&
      item.tbMeterInfoVoList != null
    ) {
      let data = item.tbMeterInfoVoList.map((itemChild) => {
        if (element === itemChild.id) {
          console.log(item);
          // text = itemChild.meterName;
          return setTextData(itemChild.meterName);
        }

        return dataString1(element, itemChild);
      });
    }
  };

  const onChange = (val: any) => {
    // console.log(val,treeDataString[val[0]]);
    console.log(treeDataString, val);
    if (!val) return;
    let text = '';
    val.forEach((element: any, index: any) => {
      // console.log(element,index,treeDataString[val[index]])
      if (val.length > 1) {
        // let data = dataString(treeDataString[val[0]].tbMeterInfoVoList,element,val)
        // console.log(data)
        for (let item of treeDataString[val[0]].tbMeterInfoVoList) {
          if (element === item.id) {
            console.log(item);
            text = item.meterName;
            setTextData(text);
            dataString1(val[val.length - 1], item);
          }
        }
      }
    });

    getListAllType(val);
    form.setFieldsValue({
      deptId1: '',
    });
    getListJianZhi(val[val.length - 1]);
  };

  return (
    <Modal
      width={700}
      title={'计算公式'}
      forceRender
      open={props.open}
      destroyOnClose
      onOk={() => {
        let label = meterItemIdFormula ? meterItemIdFormula.join('') : '';
        form.setFieldsValue({
          formula: label,
        });
        // if (!label) {
        //   return;
        // }
        console.log(label);
        let verifyState = null; // 验证状态
        let str = label.replace(/ /g, ''); // 去掉空格
        const english = new RegExp('[A-Za-z]+'); // 字母
        // 判断字符串中是否存在加减乘除
        // console.log(str.length);
        for (let i = 0; i < str.length; i++) {
          if (english.test(str[i])) {
            // 找出汉字与字母并替换成 数字 1
            str = str.replaceAll(str[i], 1);
            // 判断字符串中是否存在加减乘除
            if (!str.match(/\*|-|[/]|[+]/)) {
              verifyState = false;
              break;
            }
          }
        }
        // 如果公式错误会出现报错信息
        try {
          // 构造函数
          // 执行字符串
          let makeFun = new Function('return ' + str);
          try {
            makeFun();
            verifyState = true;
            // console.log('语法正确', makeFun());

            handleOk();
          } catch (error) {
            verifyState = false;
            // console.log('语法', makeFun());
            message.warning('计算公式语法不正确');
          }
        } catch (errorInfo) {
          verifyState = false;
          // console.log('语法正确11');
          message.warning('计算公式语法不正确');
        }
        return verifyState;
      }}
      onCancel={handleCancel}
    >
      <ProForm
        form={form}
        grid={true}
        layout="horizontal"
        submitter={false}
        onFinish={(form) => {
          form['operator'] = operator2.join('');
          form['formula'] = meterItemIdFormula.join('');
          console.log(meterItemId);
          // console.log(props.values);
          if (props.values.id) {
            form['id'] = props.values.id;
          }
          form['bcEnergyMediumVoProduct'] = props.values.bcEnergyMediumVoProduct;
          form['bcMeteringUnit'] = props.values.bcMeteringUnit;
          form['deptId'] = props.values.deptId;
          form['geo'] = props.values.geo;
          form['domain'] = props.values.domain;
          form['metric'] = props.values.metric;

          form['deptName'] = props.values.deptName;
          form['digitNum'] = props.values.digitNum;
          form['generateType'] = props.values.generateType;
          form['groupFlag'] = props.values.groupFlag;
          form['indexCode'] = props.values.indexCode;
          form['indexName'] = props.values.indexName;
          form['indexType'] = props.values.indexType;
          form['kpiDetailId'] = props.values.kpiDetailId;
          form['kpiFlag'] = props.values.kpiFlag;
          form['mediumId'] = props.values.mediumId;
          form['meterItemId'] = meterItemId.join(',');
          form['meteringUnitId'] = props.values.meteringUnitId;
          form['indexNo'] = props.values.indexNo;
          form['isEdit'] = props.values.isEdit;
          // form['meterItemIdBatch'] =
          //   meterItemIdBatch.length > 0 ? meterItemIdBatch.join('') : props.values.meterItemIdBatch;
          form['meterItemIdBatch'] = props.values?.meterItemIdBatch || '';
          // form['formulaBatch'] =
          //   formulaBatch.length > 0 ? formulaBatch.join('') : props.values.formulaBatch;

          form['formulaBatch'] = props.values.formulaBatch || '';
          console.log(form);
          handleFinish(form);
        }}
      >
        <ProFormText
          name="formula1"
          label="公式"
          colProps={{ md: 18, xl: 22 }}
          disabled={true}
          placeholder="请输入"
          rules={[
            {
              required: true,
              message: '请输入公式',
            },
          ]}
        />
        <span
          onClick={() => {
            form.setFieldsValue({
              formula: '',
              formula1: '',
            });
            setRoleName([]);
            setOperator([]);
            setMeterItemId([]);
            setMeterItemIdFormula([]);
            setOperator2([]);
          }}
        >
          清除
        </span>
        <div style={{ width: '60%' }}>
          <div style={{ display: 'flex' }}>
            <span
              style={{
                display: 'inline-block',
                width: '-webkit-fill-available',
                marginTop: '10px',
                marginLeft: '16px',
              }}
            >
              表计:
            </span>
            <div className="form-item1">
              <Cascader
                allowClear
                ref={cascaderCatergoryRef}
                expand-trigger="hover"
                changeOnSelect
                options={treeData}
                placeholder="请选择设备"
                displayRender={displayRender}
                onChange={onChange}
              />
            </div>

            <ProFormTreeSelect
              name="deptId1"
              // valueEnum={ }
              colProps={{ md: 12, xl: 8 }}
              placeholder="请选择数据项"
              valueEnum={treeData1}
              // valueEnum={treeData1}
              onChange={(val: any, option: any) => {
                // console.log(option, option.join(''));
                setDisabled(false);

                form.setFieldsValue({
                  operator: operator,
                });
                // console.log(operator2);
                console.log(option, cascaderCatergoryRef, treeDataString, textData);
                let textOption = option.map((res: string) => {
                  return textData + '.' + res;
                });
                let data = operator2.concat(textOption);
                setOperator1(textOption);
              }}
            />
            <Button
              disabled={disabled}
              onClick={() => {
                setRoleName([...roleName, form.getFieldsValue().deptId1]);
                setMeterItemId([...meterItemId, form.getFieldsValue().deptId1]);
                let data = operator2.concat(operator1);
                console.log(data, operator2, operator1, form.getFieldsValue());
                setOperator2(data);
                setMeterItemIdFormula([...meterItemIdFormula, form.getFieldsValue().deptId1]);
                let label = roleName ? roleName.join('') : '';
                console.log(operator2, operator1);

                // let data = operator2;
                form.setFieldsValue({
                  formula1: data.join(''),
                });

                form.setFieldsValue({
                  formula: label
                    ? label + form.getFieldsValue().deptId1
                    : form.getFieldsValue().deptId1,
                });
                setGongshi([...roleName, form.getFieldsValue().deptId1]);

                //二期修改 赋值
                operatorList = data.join('');
                console.log(formula1List);
                setFormula1List([...formula1List, form.getFieldsValue().deptId1]);
                setMeterItemIdList([...meterItemId, form.getFieldsValue().deptId1]);
                form.setFieldsValue({
                  deptId1: '',
                  deptId: '',
                });
                setDisabled(true);
                setOperator([...operator, operator1 ? operator1 : '']);
              }}
            >
              确认
            </Button>
          </div>
          <div style={{ marginLeft: '16px', marginBottom: '20px' }}>
            <p>产量:</p>
            {chanLiangList.length > 0 &&
              chanLiangList?.map((item) => (
                // eslint-disable-next-line react/jsx-key
                <Button
                  style={{ marginRight: '10px' }}
                  onClick={() => {
                    console.log(item);
                    setRoleName([...roleName, item.deptId]);
                    setMeterItemId([...meterItemId, item.deptId]);
                    let data = operator2.concat([item.deptName]);
                    console.log(data, operator2, operator1, item);
                    setOperator2(data);
                    setMeterItemIdFormula([...meterItemIdFormula, item.deptId]);
                    let label = roleName ? roleName.join('') : '';
                    console.log(operator2, operator1);

                    // let data = operator2;
                    form.setFieldsValue({
                      formula1: data.join(''),
                    });

                    form.setFieldsValue({
                      formula: label ? label + item.deptId : item.deptId,
                    });
                    setGongshi([...roleName, item.deptId]);

                    //二期修改 赋值
                    operatorList = data.join('');
                    // formula1List =[...formula1List, item.deptId]
                    // meterItemIdList = [...meterItemId, item.deptId]
                    console.log(formula1List);
                    setFormula1List([...formula1List, item.deptId]);
                    setMeterItemIdList([...meterItemId, item.deptId]);
                    form.setFieldsValue({
                      deptId: '',
                      deptId: '',
                    });
                    setDisabled(true);
                    setOperator([...operator, operator1 ? operator1 : '']);
                  }}
                >
                  {item.deptName}
                </Button>
              ))}
            {/* <p>经典薄片车间产量</p>
            <p>新型薄片车间产量</p> */}
          </div>
          <div className="form-item" style={{ display: 'flex' }}>
            <ProFormTreeSelect
              name="deptId2"
              label="指标"
              valueEnum={treeData2}
              colProps={{ md: 12, xl: 20 }}
              placeholder="请选择指标"
              onChange={(val: any, option: any) => {
                setDisabled1(false);
                setOperator1(option);

                form.setFieldsValue({
                  operator: operator,
                  operator2: operator,
                });
              }}
            />
            <Button
              disabled={disabled1}
              onClick={() => {
                setRoleName([...roleName, form.getFieldsValue().deptId2]);
                setMeterItemId([...meterItemId, form.getFieldsValue().deptId2]);

                setMeterItemIdFormula([...meterItemIdFormula, form.getFieldsValue().deptId2]);
                let label = roleName ? roleName.join('') : '';
                let data = operator2.concat(operator1);
                // console.log(data, operator2, operator1, form.getFieldsValue());
                setOperator2(data);
                form.setFieldsValue({
                  formula: label
                    ? label + form.getFieldsValue().deptId2
                    : form.getFieldsValue().deptId2,
                });
                form.setFieldsValue({
                  formula1: operator2.length > 0 ? data.join('') : data.join(''),
                });
                setGongshi([...roleName, form.getFieldsValue().deptId2]);
                //二期修改 赋值
                console.log(formula1List, form.getFieldsValue());
                operatorList = operator2.length > 0 ? data.join('') : data.join('');
                setFormula1List([...formula1List, form.getFieldsValue().deptId2]);
                setMeterItemIdList([...meterItemId, form.getFieldsValue().deptId2]);
                form.setFieldsValue({
                  deptId1: '',
                  deptId: '',
                  deptId2: '',
                });
                setDisabled1(true);
                setOperator([...operator, operator1 ? operator1 : '']);
              }}
            >
              确认
            </Button>
          </div>
        </div>
        <div style={{ width: '32%', marginLeft: '20px', textAlign: 'right' }}>
          {jiData.map((item, index) => (
            <div key={index}>
              {item.map((list, index1) => (
                <span
                  key={index1}
                  style={{
                    width: list.lable === '=' ? '100px' : '50px',
                    height: '50px',
                    background: '#fff',
                    lineHeight: '50px',
                    color: '#000',
                    display: 'inline-block',
                    textAlign: 'center',
                    fontSize: '18px',
                    border: '1px solid #999',
                  }}
                  onClick={() => {
                    console.log(formula1List);
                    if (list.lable === 'AC') {
                      // 二期修改
                      // 正则表达是去掉+-*/
                      let operator =
                        typeof operatorList === 'string'
                          ? operatorList?.split(/\s*(\+|-|\*|\/)\s*/)
                          : operatorList;
                      let meterItemId =
                        typeof meterItemIdList === 'string'
                          ? meterItemIdList?.split(/\s*(,)\s*/)
                          : meterItemIdList;
                      let Formula =
                        typeof formula1List === 'string'
                          ? formula1List?.split(/\s*(\+|-|\*|\/)\s*/)
                          : formula1List;
                      // 过滤已删除
                      operator = operator.filter((l) => l != '');
                      Formula = Formula.filter((l) => l != '');
                      // 后往前删
                      let operatorArr = operator.splice(operator.length - 1, 1);
                      let FormulaArr = Formula.splice(Formula.length - 1, 1);
                      console.log(Formula, FormulaArr);
                      // 一期
                      form.setFieldsValue({
                        formula: operator.join(''),
                        formula1: operator.join(''),
                      });
                      // 删除赋值
                      operatorList = operator.filter((l) => l != '').join('');
                      setFormula1List(Formula.filter((l) => l != '').join(''));
                      console.log(Formula.join('').replace(/[(+|\-|*|/)]/g, ','));
                      let list = Formula.join('').replace(/[(+|\-|*|/)]/g, ',');
                      console.log(list.split());
                      setRoleName([]);
                      setOperator(operator);
                      setGongshi([]);
                      setMeterItemId(list.split());
                      setOperator2(operator);
                      setMeterItemIdFormula(Formula);
                      return;
                    }
                    let label = roleName ? roleName.join('') : '';
                    form.setFieldsValue({
                      formula: label ? label + list.lable : list.lable,
                    });
                    let data = operator2.concat([list.lable]);
                    setOperator2(data);
                    let label1 = operator2 ? operator2.join('') : '';
                    console.log(label1, list, operator, operator2);
                    form.setFieldsValue({
                      formula1: label1 ? label1 + list.lable : list.lable,
                    });
                    console.log(operator, 'operator');
                    setRoleName([...roleName, list.lable]);
                    // let meterItem = meterItemId ? meterItemId.join('') : '';
                    let MeterItemId = meterItemIdFormula.concat([list.lable]);
                    console.log(MeterItemId.join(''), MeterItemId);
                    setMeterItemIdFormula(MeterItemId);
                    setMeterItemIdFormula(_.cloneDeep(MeterItemId));
                    console.log(meterItemIdFormula);
                    setGongshi([...roleName, list.lable]);
                    setOperator([...operator, list.lable]); //回显
                    //二期修改 赋值
                    operatorList = data.join('');
                    setFormula1List([...formula1List, list.lable]);
                    setMeterItemIdList(meterItemId);
                    form.setFieldsValue({
                      operator: operator,
                    });
                  }}
                >
                  {list.lable}
                </span>
              ))}
            </div>
          ))}
        </div>
      </ProForm>
    </Modal>
  );
};

export default RoleForm;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1367410.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

带前后端H5即时通讯聊天系统源码

带有前后端的H5即时通讯聊天系统源码。该源码是一个开源的即时通信demo&#xff0c;需要前后端配合使用。它的主要目的是为了促进学习和交流&#xff0c;并为大家提供开发即时通讯功能的思路。尽管该源码提供了许多功能&#xff0c;但仍需要进行自行开发。该项目最初的开发初衷…

CVE-2023-36025 Windows SmartScreen 安全功能绕过漏洞

CVE-2023-36025是微软于11月补丁日发布的安全更新中修复Windows SmartScreen安全功能绕过漏洞。攻击者可以通过诱导用户单击特制的URL来利用该漏洞&#xff0c;对目标系统进行攻击。成功利用该漏洞的攻击者能够绕过Windows Defender SmartScreen检查及其相关提示。该漏洞的攻击…

伦敦银1盎司等于多少克?

1盎司的伦敦银大概等于31克&#xff0c;用于衡量伦敦银重量的“盎司”&#xff0c;是国际贵金属市场上专用的计量单位&#xff0c;它的全称是金衡盎司&#xff0c;英文的名字是troy ounce&#xff0c;它与西方日常用于计算重量的单位常衡盎司也不一样&#xff0c;一金衡盎司约等…

[论文阅读]4DRadarSLAM: A 4D Imaging Radar SLAM System for Large-scale Environments

目录 1.摘要和引言&#xff1a; 2. 系统框架&#xff1a; 2.1 前端&#xff1a; 2.2 回环检测&#xff1a; 2.3 后端&#xff1a; 3.实验和分析&#xff1a; 4.结论 1.摘要和引言&#xff1a; 这篇论文介绍了一种名为“4DRadarSLAM”的新型4D成像雷达SLAM系统&#xff0…

【ChatGPT+】创新与教育的交汇点:中国训练工程师的崛起

人工智能总价值超15.7万亿美元 根据国际数据公司&#xff08;IDC&#xff09;的预测&#xff0c;到2030年&#xff0c;全球人工智能市场总价值将超过15.7万亿美元&#xff0c;这表明人工智能技术将在未来几十年内得到广泛应用并取得长足发展。 人工智能的快速发展将对各个领域…

JAVA基础语句1

目录 前言 一.JAVA特性 简单 面向对象 分布式 多线程 二.关键字 三.对象和类 对象 类 构造方法 创建对象 访问实例变量和方法 源文件声明规则 Java 包 import 语句 总结 前言 这里参考了&#xff1a;Java 教程 | 菜鸟教程 (runoob.com) 第一个必须是&#xff1a; hello world&a…

2024腾讯云免费服务器申请入口,限制及申请攻略亲测!

腾讯云免费服务器申请入口 https://curl.qcloud.com/FJhqoVDP 免费服务器可选轻量应用服务器和云服务器CVM&#xff0c;轻量配置可选2核2G3M、2核8G7M和4核8G12M&#xff0c;CVM云服务器可选2核2G3M和2核4G3M配置&#xff0c;腾讯云百科txybk.com分享2024年最新腾讯云免费服务器…

idea修改pom.xml没有重新导入maven的按钮

问题描述&#xff1a; IDEA修改pom.xml配置以后&#xff0c;不会展示 Load Maven Changes弹窗。 解决方法&#xff1a; 方式一、pom.xml右键&#xff0c;Maven--Run Maven--Reimport。但我感觉这个太麻烦了。 方式2、选择Building Tool Settings&#xff0c;点击Auto-Reload …

指针传参误区

C语言中指针作为形参传递时&#xff0c;func&#xff08;*a, *b&#xff09; 这种形式的话&#xff0c;是无法通过简单的 ab来修改的&#xff0c;在函数体内a的地址确实被修改成b的地址了&#xff0c;但是当函数执行结束时&#xff0c;a的地址会重新回到原本的地址里面&#xf…

目标检测-One Stage-CenterNet

文章目录 前言一、CenterNet的网络结构和流程二、CenterNet的创新点总结 前言 前文提到的YOLOv3、YOLOv4、YOLOv5都是基于Anchor的算法&#xff08;anchor-based&#xff09;&#xff0c;这类算法有如下缺点&#xff1a; 产生大量的预测框&#xff0c;计算量大正负样本不平衡…

2024最新腾讯云CVM服务器和轻量应用服务器有什么区别?

腾讯云轻量服务器和云服务器CVM该怎么选&#xff1f;不差钱选云服务器CVM&#xff0c;追求性价比选择轻量应用服务器&#xff0c;轻量真优惠呀&#xff0c;腾讯云服务器网txyfwq.com活动 https://curl.qcloud.com/oRMoSucP 轻量应用服务器2核2G3M价格62元一年、2核2G4M价格118元…

idea 社区版 Database Navigator插件 列显示顺序错乱解决办法

idea 社区版 Database Navigator插件 列显示顺序错乱 影响&#xff1a;MyBatisCodeHelperPro插件生成代码字段顺序错乱 解决办法&#xff1a;将COLUMN 的排序方式由Name改为Position方式之后&#xff0c;reload即可&#xff01;

Sortable.js:功能强大的JavaScript 拖拽库

原文地址&#xff1a;Sortable.js&#xff1a;功能强大的JavaScript 拖拽库 一、介绍 Sortable.js一个功能强大的JavaScript 拖拽库&#xff01;&#xff01;&#xff01;用于在网页上创建可拖放和可排序的元素。它提供了简单而强大的 API&#xff0c;使开发人员能够轻松地实…

广联达Linkworks DataExchange.ashx XXE漏洞复现

0x01 产品简介 广联达 LinkWorks(也称为 GlinkLink 或 GTP-LinkWorks)是广联达公司(Glodon)开发的一种BIM(建筑信息模型)协同平台。广联达是中国领先的数字建造技术提供商之一,专注于为建筑、工程和建筑设计行业提供数字化解决方案。 0x02 漏洞概述 广联达 LinkWorks …

如何使用HadSky搭配内网穿透工具搭建本地论坛并发布至公网可远程访问

目录 前言 1. 网站搭建 1.1 网页下载和安装 1.2 网页测试 1.3 cpolar的安装和注册 2. 本地网页发布 2.1 Cpolar临时数据隧道 2.2 Cpolar稳定隧道&#xff08;云端设置&#xff09; 2.3 Cpolar稳定隧道&#xff08;本地设置&#xff09; 2.4 公网访问测试 总结 前言 …

影视仓最新配置接口2024tvbox源配置地址

影视仓是在TVBox开源代码基础上开发的优质版本&#xff0c;安装后需要配置接口才能正常使用。影视仓"内置版"是开发者做的资源内置化修改版本&#xff0c;不用自行设置接口&#xff0c;安装后即可使用。 影视仓的接口配置方法与TVBOX一样&#xff0c;区别在于影视仓…

算法第十四天-删除有序数组中的重复项

删除有序数组中的重复项 题目要求 解题思路 双指针 左指针确定不重复值&#xff0c;右指针遍历数组 代码 class Solution:def removeDuplicates(self, nums: List[int]) -> int:left0for right in range(1,len(nums)):if nums[left] ! nums[right]:left 1nums[left] nu…

快速指南:原型图的基础知识解析

什么是原型图 一般来说&#xff0c;原型图是指用于呈现软件产品功能界面、交互设计和逻辑过程的设计项目。您还可以将原型图理解为软件的草图&#xff0c;可以通过原型图清楚地说明软件的功能、几个界面、每个功能的功能以及每个界面的流通关系。 原型图中的组成内容不是固定…

Java知识点:泛型、类加载器、内部类、可变参数

文章目录 1、this关键字2、泛型2.1 泛型介绍2.2 泛型分类定义2.2.1 泛型类2.2.2 泛型方法2.2.3 泛型接口 2.3 泛型通配符 3、可变参数4、日志4.1 使用步骤4.2 日志级别4.3 配置文件 5、类加载器5.1 类加载器5.2 类加载的完整过程5.2.1 类加载时机5.2.2 类加载过程 5.3 类加载的…

密码学:一文读懂非对称加密算法 DH、RSA

文章目录 前言非对称加密算法的由来非对称加密算法的家谱1.基于因子分解难题2.基于离散对数难题 密钥交换算法-DH密钥交换算法-DH的通信模型初始化DH算法密钥对甲方构建DH算法本地密钥乙方构建DH算法本地密钥DH算法加密消息传递 典型非对称加密算法-RSARSA的通信模型RSA特有的的…