schangxiang@126.com
2025-09-10 3d43ffa3152110b7823f9fa6320c08a6ae02358a
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
125
126
127
128
<template>
  <div class="page-list-container">
    <!--数据Table-->
    <yrt-data-list :ref="dataListRef" :editor-ref="editorRef" :data-options="dataOptions" :fields.sync="dataListOptions.fields" :buttons="dataListOptions.buttons" :button-click="buttonClick" :data-list-selections.sync="dataListSelections" :auth-nodes="authNodes">
      <template slot="common-column-slot" slot-scope="{row, col}">
        <template v-if="['enable', 'isDefaultAddress'].indexOf(col.prop)>=0">
          <template v-if="row[col.prop]==1">
            <el-tag color="#7aaffe" style="color:white;border:0">
              {{ $refs[dataListRef].translateText(col.prop, row[col.prop], col.dropdown_Id) }}
            </el-tag>
          </template>
          <template v-else>
            <el-tag color="#ffcc33" style="color:white;border:0">
              {{ $refs[dataListRef].translateText(col.prop, row[col.prop]||0, col.dropdown_Id) }}
            </el-tag>
          </template>
        </template>
        <template v-else>
          {{ row[col.prop] }}
        </template>
      </template>
    </yrt-data-list>
 
    <!--数据编辑器Editor-->
    <yrt-editor :ref="editorRef" :data-list-ref="dataListRef" v-bind="editorOptions" :data-options="dataOptions" :action.sync="editorOptions.action" :visible.sync="editorOptions.config.visible" :detail-button-click="detailButtonClick" :auth-nodes="authNodes" @on-change="onChange"></yrt-editor>
  </div>
</template>
 
<script>
import baseLayout from "@/components/common/base-layout.vue";
 
export default {
  name: "account-address",
  // 自定义JSON路由地址
  custoJsonmRoute: "/user/account/address",
 
  components: {},
  mixins: [baseLayout],
  data() {
    return {
      authNodes: {
        add: true,
        delete: true,
        export: true,
        save: true
      }
    };
  },
  methods: {
    // 级联改变数据
    onChange(ref, val, field) {
      // 记录ID和Name
      if (field.options.prop === "provinceName") {
        // 设置表单数据
        const item = ref.getOption(val);
        // 改变市级下拉框
        this.loadChildrenNode(item.value, 614, field.options.prop);
      } else if (field.options.prop === "cityName") {
        // 设置表单数据
        const item = ref.getOption(val);
        // 改变区级下拉框
        this.loadChildrenNode(item.value, 615, field.options.prop);
      }
    },
    // 根据省ID获得市
    loadChildrenNode(id, dropdown_Id, prop) {
      var the = this;
      var editorRef = this.editor;
 
      var where = { parentId: id };
      var url = "/api/common/loadTreeNode";
      var params = {
        folder: "basicInfo/base",
        dbServer: "Sys",
        tableName: "Base_City",
        tableView: "Base_City",
        keyName: "city_Id",
        nodeName: "cityName",
        fixHasChild: false,
        isBreakWay: false,
        displayBreakWay: false,
        parentName: "parentId",
        orderBy: "orderNo desc, city_Id",
        where: where,
        extendColumns: ""
      };
      the.common.ajax(
        url,
        params,
        res => {
          if (res.result) {
            var data = res.data.map(item => {
              if (prop === "provinceName") {
                const newItem = {
                  city_Id: item.value,
                  cityName: item.label,
                  value: item.value,
                  label: item.label
                };
                return newItem;
              } else if (prop === "cityName") {
                const newItem = {
                  Region_Id: item.value,
                  RegionName: item.label,
                  value: item.value,
                  label: item.label
                };
                return newItem;
              }
            });
            editorRef.setDropdownData(dropdown_Id, data);
          } else {
            the.$message.error(res.msg);
          }
        },
        true
      );
    },
    // 编辑前事件
    onEditLoadAfter(formData) {
      // 加载市
      this.loadChildrenNode(formData.Province_Id, 614, "provinceName");
      // 加载市
      this.loadChildrenNode(formData.city_Id, 615, "cityName");
    }
  }
};
</script>