schangxiang@126.com
2025-09-19 df5675b4e548eff2dbab6c780b173c346551f508
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
function findRemoteFunc(fields, funcList, tokenFuncList, blankList) {
  for (let i = 0; i < fields.length; i++) {
    if (fields[i].type === "grid") {
      fields[i].columns.forEach((item) => {
        findRemoteFunc(item.fields, funcList, tokenFuncList, blankList);
      });
    } else {
      if (fields[i].type === "blank") {
        if (fields[i].model) {
          blankList.push({
            model: fields[i].model,
            label: fields[i].label
          });
        }
      } else if (fields[i].type === "imgupload") {
        if (fields[i].options.tokenFunc) {
          tokenFuncList.push({
            func: fields[i].options.tokenFunc,
            label: fields[i].label,
            model: fields[i].model
          });
        }
      } else {
        if (fields[i].options.remote && fields[i].options.remoteFunc) {
          funcList.push({
            func: fields[i].options.remoteFunc,
            label: fields[i].label,
            model: fields[i].model
          });
        }
      }
    }
  }
}
 
export default function(data) {
  const funcList = [];
 
  const tokenFuncList = [];
 
  const blankList = [];
 
  findRemoteFunc(
    JSON.parse(data).editorOptions.fields,
    funcList,
    tokenFuncList,
    blankList
  );
 
  let funcTemplate = "";
 
  let blankTemplate = "";
 
  for (let i = 0; i < funcList.length; i++) {
    funcTemplate += `
            ${funcList[i].func} (resolve) {
              //  ${funcList[i].label} ${funcList[i].model}
              //  获取到远端数据后执行回调函数
              //  resolve(data)
            },
    `;
  }
 
  for (let i = 0; i < tokenFuncList.length; i++) {
    funcTemplate += `
            ${tokenFuncList[i].func} (resolve) {
              //  ${tokenFuncList[i].label} ${tokenFuncList[i].model}
              //  获取到token数据后执行回调函数
              //  resolve(token)
            },
    `;
  }
 
  for (let i = 0; i < blankList.length; i++) {
    blankTemplate += `
        <template slot="${blankList[i].label}" slot-scope="scope">
          <!-- ${blankList[i].label} -->
          <!-- 通过 v-model="scope.model.${blankList[i].label}" 绑定数据 -->
        </template>
    `;
  }
 
  return `<!DOCTYPE html>
  <html>
  <head>
    <meta charset="UTF-8">
    <link rel="stylesheet" href="https:// unpkg.com/element-ui/lib/theme-chalk/index.css">
    <link rel="stylesheet" href="https:// unpkg.com/form-making/dist/FormMaking.css">
  </head>
  <body>
    <div id="app">
      <fm-generate-form :data="jsonData" :remote="remoteFuncs" :value="editData" ref="generateForm">
        ${blankTemplate}
      </fm-generate-form>
      <el-button type="primary" @click="handleSubmit">提交</el-button>
    </div>
    <script src="https:// unpkg.com/vue/dist/vue.js"></script>
    <script src="https:// unpkg.com/element-ui/lib/index.js"></script>
    <script src="https:// unpkg.com/form-making/dist/FormMaking.umd.js"></script>
    <script>
      new Vue({
        el: '#app',
        data: {
          jsonData: ${data},
          editData: {},
          remoteFuncs: {
            ${funcTemplate}
          }
        },
        methods: {
          handleSubmit () {
            this.$refs.generateForm.getData().then(data => {
              //  数据校验成功
              //  data 为获取的表单数据
            }).catch(e => {
              //  数据校验失败
            })
          }
        }
      })
    </script>
  </body>
  </html>`;
}