oxy-uni-ui 2.1.1 → 2.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (183) hide show
  1. package/attributes.json +1 -1
  2. package/components/common/abstracts/variable.scss +13 -2
  3. package/components/oxy-checkbox/index.scss +37 -2
  4. package/components/oxy-sort-button/index.scss +3 -4
  5. package/components/oxy-tag/index.scss +157 -17
  6. package/components/oxy-tag/oxy-tag.vue +14 -2
  7. package/components/oxy-tag/types.ts +9 -0
  8. package/dev-tools.ts +2 -0
  9. package/devTools/components/DevToolsOverlay.vue +56 -0
  10. package/devTools/components/DevToolsUiHost.vue +589 -0
  11. package/devTools/config.js +55 -0
  12. package/devTools/core/components/mpDevBubble.vue +174 -0
  13. package/devTools/core/libs/createH5Bubble.js +156 -0
  14. package/devTools/core/libs/devCache.js +151 -0
  15. package/devTools/core/libs/devOptions.js +163 -0
  16. package/devTools/core/libs/devUi.js +219 -0
  17. package/devTools/core/libs/drawView.js +140 -0
  18. package/devTools/core/libs/errorReport.js +64 -0
  19. package/devTools/core/libs/jsonCompress.js +334 -0
  20. package/devTools/core/libs/logReport.js +59 -0
  21. package/devTools/core/libs/pageLinkList.js +125 -0
  22. package/devTools/core/libs/timeFormat.js +94 -0
  23. package/devTools/core/proxy/console.js +430 -0
  24. package/devTools/core/proxy/index.js +36 -0
  25. package/devTools/core/proxy/request.js +495 -0
  26. package/devTools/core/proxy/storage.js +113 -0
  27. package/devTools/core/proxy/uniBus.js +153 -0
  28. package/devTools/core/proxy/uniListen.js +192 -0
  29. package/devTools/core/proxy/vueMixin.js +120 -0
  30. package/devTools/index.js +168 -0
  31. package/devTools/page/components/bottomTools.vue +1046 -0
  32. package/devTools/page/components/dialog/addStorage.vue +204 -0
  33. package/devTools/page/components/dialog/createDir.vue +366 -0
  34. package/devTools/page/components/dialog/editDialog.vue +192 -0
  35. package/devTools/page/components/dialog/routeDialog.vue +184 -0
  36. package/devTools/page/components/dialog/sendRequest.vue +603 -0
  37. package/devTools/page/components/dialog/textFileEditDialog.vue +391 -0
  38. package/devTools/page/components/libs/appDelDir.js +86 -0
  39. package/devTools/page/components/libs/dirReader.js +248 -0
  40. package/devTools/page/components/libs/fileSize.js +15 -0
  41. package/devTools/page/components/libs/getRuntimeInfo.js +134 -0
  42. package/devTools/page/components/listItem/consoleItem.vue +314 -0
  43. package/devTools/page/components/listItem/errorItem.vue +292 -0
  44. package/devTools/page/components/listItem/fileSysItem.vue +533 -0
  45. package/devTools/page/components/listItem/infoList.vue +100 -0
  46. package/devTools/page/components/listItem/jsRunnerItem.vue +255 -0
  47. package/devTools/page/components/listItem/logItem.vue +193 -0
  48. package/devTools/page/components/listItem/networkItem.vue +398 -0
  49. package/devTools/page/components/listItem/objectAnalysis.vue +651 -0
  50. package/devTools/page/components/listItem/pages.vue +319 -0
  51. package/devTools/page/components/listItem/routeItem.vue +153 -0
  52. package/devTools/page/components/listItem/setting.vue +734 -0
  53. package/devTools/page/components/listItem/storageList.vue +681 -0
  54. package/devTools/page/components/listItem/tools.vue +315 -0
  55. package/devTools/page/components/listItem/vuexList.vue +599 -0
  56. package/devTools/page/components/main.vue +1867 -0
  57. package/devTools/page/components/mixins/animationControl.js +91 -0
  58. package/devTools/page/components/mixins/mp.js +83 -0
  59. package/devTools/page/components/ui/btnTabs.vue +90 -0
  60. package/devTools/page/components/ui/codeHisPicker.vue +172 -0
  61. package/devTools/page/components/ui/h5Cell.vue +13 -0
  62. package/devTools/page/components/ui/menuBtn.vue +94 -0
  63. package/devTools/page/components/ui/mobileSwiperScroll.vue +74 -0
  64. package/devTools/page/components/ui/requestSpeedLimit.vue +52 -0
  65. package/devTools/page/components/ui/requestTimeoutMock.vue +55 -0
  66. package/devTools/page/components/ui/subTitleBar.vue +101 -0
  67. package/devTools/page/static/copy.png +0 -0
  68. package/devTools/page/static/delete.png +0 -0
  69. package/devTools/page/static/fileSys/AI.png +0 -0
  70. package/devTools/page/static/fileSys/DWG.png +0 -0
  71. package/devTools/page/static/fileSys/EXE.png +0 -0
  72. package/devTools/page/static/fileSys/GIF.png +0 -0
  73. package/devTools/page/static/fileSys/HTML.png +0 -0
  74. package/devTools/page/static/fileSys/PSD.png +0 -0
  75. package/devTools/page/static/fileSys/RVT.png +0 -0
  76. package/devTools/page/static/fileSys/SKP.png +0 -0
  77. package/devTools/page/static/fileSys/SVG.png +0 -0
  78. package/devTools/page/static/fileSys/excel.png +0 -0
  79. package/devTools/page/static/fileSys/pdf.png +0 -0
  80. package/devTools/page/static/fileSys/pptl.png +0 -0
  81. package/devTools/page/static/fileSys/shipin.png +0 -0
  82. package/devTools/page/static/fileSys/tupian.png +0 -0
  83. package/devTools/page/static/fileSys/txt.png +0 -0
  84. package/devTools/page/static/fileSys/weizhiwenjian.png +0 -0
  85. package/devTools/page/static/fileSys/wenjianjia.png +0 -0
  86. package/devTools/page/static/fileSys/word.png +0 -0
  87. package/devTools/page/static/fileSys/yasuo.png +0 -0
  88. package/devTools/page/static/fileSys/yinpin.png +0 -0
  89. package/devTools/page/static/fold.png +0 -0
  90. package/devTools/page/static/menu.png +0 -0
  91. package/devTools/page/static/refresh.png +0 -0
  92. package/devTools/page/static/unfold.png +0 -0
  93. package/devTools/tools.vue +25 -0
  94. package/devTools/type/devTools.d.ts +406 -0
  95. package/oxy-dev-tools/components/DevToolsUiHost.vue +555 -0
  96. package/oxy-dev-tools/config.js +61 -0
  97. package/oxy-dev-tools/core/components/mpDevBubble.vue +176 -0
  98. package/oxy-dev-tools/core/libs/createH5Bubble.js +156 -0
  99. package/oxy-dev-tools/core/libs/devCache.js +149 -0
  100. package/oxy-dev-tools/core/libs/devOptions.js +160 -0
  101. package/oxy-dev-tools/core/libs/devUi.js +219 -0
  102. package/oxy-dev-tools/core/libs/drawView.js +144 -0
  103. package/oxy-dev-tools/core/libs/errorReport.js +60 -0
  104. package/oxy-dev-tools/core/libs/jsonCompress.js +328 -0
  105. package/oxy-dev-tools/core/libs/logReport.js +55 -0
  106. package/oxy-dev-tools/core/libs/pageLinkList.js +121 -0
  107. package/oxy-dev-tools/core/libs/timeFormat.js +93 -0
  108. package/oxy-dev-tools/core/proxy/console.js +398 -0
  109. package/oxy-dev-tools/core/proxy/index.js +33 -0
  110. package/oxy-dev-tools/core/proxy/request.js +473 -0
  111. package/oxy-dev-tools/core/proxy/storage.js +96 -0
  112. package/oxy-dev-tools/core/proxy/uniBus.js +148 -0
  113. package/oxy-dev-tools/core/proxy/uniListen.js +190 -0
  114. package/oxy-dev-tools/core/proxy/vueMixin.js +115 -0
  115. package/oxy-dev-tools/index.ts +183 -0
  116. package/oxy-dev-tools/oxy-dev-tools.vue +62 -0
  117. package/oxy-dev-tools/page/components/bottomTools.vue +933 -0
  118. package/oxy-dev-tools/page/components/dialog/addStorage.vue +184 -0
  119. package/oxy-dev-tools/page/components/dialog/createDir.vue +352 -0
  120. package/oxy-dev-tools/page/components/dialog/editDialog.vue +178 -0
  121. package/oxy-dev-tools/page/components/dialog/routeDialog.vue +170 -0
  122. package/oxy-dev-tools/page/components/dialog/sendRequest.vue +530 -0
  123. package/oxy-dev-tools/page/components/dialog/textFileEditDialog.vue +379 -0
  124. package/oxy-dev-tools/page/components/libs/appDelDir.js +77 -0
  125. package/oxy-dev-tools/page/components/libs/dirReader.js +239 -0
  126. package/oxy-dev-tools/page/components/libs/fileSize.js +15 -0
  127. package/oxy-dev-tools/page/components/libs/getRuntimeInfo.js +132 -0
  128. package/oxy-dev-tools/page/components/listItem/consoleItem.vue +292 -0
  129. package/oxy-dev-tools/page/components/listItem/errorItem.vue +268 -0
  130. package/oxy-dev-tools/page/components/listItem/fileSysItem.vue +511 -0
  131. package/oxy-dev-tools/page/components/listItem/infoList.vue +89 -0
  132. package/oxy-dev-tools/page/components/listItem/jsRunnerItem.vue +236 -0
  133. package/oxy-dev-tools/page/components/listItem/logItem.vue +185 -0
  134. package/oxy-dev-tools/page/components/listItem/networkItem.vue +362 -0
  135. package/oxy-dev-tools/page/components/listItem/objectAnalysis.vue +642 -0
  136. package/oxy-dev-tools/page/components/listItem/pages.vue +285 -0
  137. package/oxy-dev-tools/page/components/listItem/routeItem.vue +140 -0
  138. package/oxy-dev-tools/page/components/listItem/setting.vue +687 -0
  139. package/oxy-dev-tools/page/components/listItem/storageList.vue +623 -0
  140. package/oxy-dev-tools/page/components/listItem/tools.vue +273 -0
  141. package/oxy-dev-tools/page/components/listItem/vuexList.vue +559 -0
  142. package/oxy-dev-tools/page/components/main.vue +1824 -0
  143. package/oxy-dev-tools/page/components/mixins/animationControl.js +80 -0
  144. package/oxy-dev-tools/page/components/mixins/mp.js +76 -0
  145. package/oxy-dev-tools/page/components/ui/btnTabs.vue +77 -0
  146. package/oxy-dev-tools/page/components/ui/codeHisPicker.vue +161 -0
  147. package/oxy-dev-tools/page/components/ui/h5Cell.vue +13 -0
  148. package/oxy-dev-tools/page/components/ui/menuBtn.vue +87 -0
  149. package/oxy-dev-tools/page/components/ui/mobileSwiperScroll.vue +71 -0
  150. package/oxy-dev-tools/page/components/ui/requestSpeedLimit.vue +47 -0
  151. package/oxy-dev-tools/page/components/ui/requestTimeoutMock.vue +50 -0
  152. package/oxy-dev-tools/page/components/ui/subTitleBar.vue +87 -0
  153. package/oxy-dev-tools/page/static/copy.png +0 -0
  154. package/oxy-dev-tools/page/static/delete.png +0 -0
  155. package/oxy-dev-tools/page/static/fileSys/AI.png +0 -0
  156. package/oxy-dev-tools/page/static/fileSys/DWG.png +0 -0
  157. package/oxy-dev-tools/page/static/fileSys/EXE.png +0 -0
  158. package/oxy-dev-tools/page/static/fileSys/GIF.png +0 -0
  159. package/oxy-dev-tools/page/static/fileSys/HTML.png +0 -0
  160. package/oxy-dev-tools/page/static/fileSys/PSD.png +0 -0
  161. package/oxy-dev-tools/page/static/fileSys/RVT.png +0 -0
  162. package/oxy-dev-tools/page/static/fileSys/SKP.png +0 -0
  163. package/oxy-dev-tools/page/static/fileSys/SVG.png +0 -0
  164. package/oxy-dev-tools/page/static/fileSys/excel.png +0 -0
  165. package/oxy-dev-tools/page/static/fileSys/pdf.png +0 -0
  166. package/oxy-dev-tools/page/static/fileSys/pptl.png +0 -0
  167. package/oxy-dev-tools/page/static/fileSys/shipin.png +0 -0
  168. package/oxy-dev-tools/page/static/fileSys/tupian.png +0 -0
  169. package/oxy-dev-tools/page/static/fileSys/txt.png +0 -0
  170. package/oxy-dev-tools/page/static/fileSys/weizhiwenjian.png +0 -0
  171. package/oxy-dev-tools/page/static/fileSys/wenjianjia.png +0 -0
  172. package/oxy-dev-tools/page/static/fileSys/word.png +0 -0
  173. package/oxy-dev-tools/page/static/fileSys/yasuo.png +0 -0
  174. package/oxy-dev-tools/page/static/fileSys/yinpin.png +0 -0
  175. package/oxy-dev-tools/page/static/fold.png +0 -0
  176. package/oxy-dev-tools/page/static/menu.png +0 -0
  177. package/oxy-dev-tools/page/static/refresh.png +0 -0
  178. package/oxy-dev-tools/page/static/unfold.png +0 -0
  179. package/oxy-dev-tools/tools.vue +22 -0
  180. package/oxy-dev-tools/type/devTools.d.ts +406 -0
  181. package/package.json +1 -1
  182. package/tags.json +1 -1
  183. package/web-types.json +1 -1
@@ -0,0 +1,651 @@
1
+ <template>
2
+ <view
3
+ class="objectAnalysis"
4
+ :style="{
5
+ width: width + 'rpx',
6
+ }"
7
+ >
8
+ <view
9
+ class="objectTitle objectTitleActive"
10
+ @click="titleClick"
11
+ >
12
+ <image class="foldItem" v-if="isOpen" src="@/devTools/page/static/fold.png" />
13
+ <image class="foldItem" v-else src="@/devTools/page/static/unfold.png" />
14
+ <text
15
+ class="title"
16
+ :style="{
17
+ width: width - 50 + 'rpx',
18
+ }"
19
+ >
20
+ {{ title }}
21
+ </text>
22
+ </view>
23
+
24
+ <view
25
+ class="objectList"
26
+ v-if="isOpen"
27
+ :style="{
28
+ width: width + 'rpx',
29
+ }"
30
+ >
31
+ <view
32
+ v-for="(item, index) in list"
33
+ :key="item.i"
34
+ class="listItem"
35
+ :style="{
36
+ marginLeft: item.l + 'rpx',
37
+ }"
38
+ @click="rowClick(item, index)"
39
+ >
40
+ <template v-if="item.t == 'array' || item.t == 'object'">
41
+ <image class="foldItem" v-if="item.o" src="@/devTools/page/static/fold.png" />
42
+ <image class="foldItem" v-else src="@/devTools/page/static/unfold.png" />
43
+ </template>
44
+ <view
45
+ v-else
46
+ class="emptyFold"
47
+ ></view>
48
+ <text
49
+ class="objKey"
50
+ :class="'t-' + item.t"
51
+ :style="{
52
+ maxWidth: (width - item.l - 40) / 2 + 'rpx',
53
+ }"
54
+ >
55
+ {{ item.k }}:
56
+ </text>
57
+ <text
58
+ class="objValue"
59
+ :class="'t-' + item.t"
60
+ >
61
+ {{ item.vt }}
62
+ </text>
63
+ </view>
64
+ </view>
65
+ </view>
66
+ </template>
67
+ <script>
68
+ import jsonCompress from "../../../core/libs/jsonCompress";
69
+ function getType(v) {
70
+ return Object.prototype.toString.call(v).slice(8, -1).toLocaleLowerCase();
71
+ }
72
+ function randId() {
73
+ return Math.ceil(Math.random() * 1000000000000000);
74
+ }
75
+ export default {
76
+ props: {
77
+ /**
78
+ * 需要解析的对象数据
79
+ */
80
+ data: "",
81
+ /**
82
+ * 组件宽度 rpx
83
+ */
84
+ width: {
85
+ type: Number,
86
+ default: 610,
87
+ },
88
+ /**
89
+ * 是否默认展开第一层
90
+ */
91
+ isOpenFirst: {
92
+ type: Boolean,
93
+ default: false,
94
+ },
95
+ /**
96
+ * 是否展示完整的对象类型
97
+ */
98
+ showObjProto: {
99
+ type: Boolean,
100
+ default: false,
101
+ },
102
+ },
103
+ data() {
104
+ return {
105
+ /**
106
+ * 对象类型 array object map unknown
107
+ */
108
+ type: "unknown",
109
+ /**
110
+ * 对象标题
111
+ */
112
+ title: "",
113
+ /**
114
+ * 是否为开启节点状态
115
+ */
116
+ isOpen: false,
117
+ /**
118
+ * 渲染的列表
119
+ */
120
+ list: [
121
+ {
122
+ t: "text", // 类型
123
+ k: "键名", // key
124
+ v: "名称", // value
125
+ vt: "", //view层渲染的文字
126
+ i: "s", //节点id
127
+ p: "0", //父节点id
128
+ o: true, //是否开启下级
129
+ l: 0, // 距离左侧长度
130
+ d: null, //原对象
131
+ },
132
+ ],
133
+ };
134
+ },
135
+ mounted() {
136
+ let that = this;
137
+
138
+ try {
139
+ let { title } = that.getObjType(this.data);
140
+ that.list = [];
141
+ that.title = title;
142
+ if (that.isOpenFirst) {
143
+ that.titleClick();
144
+ }
145
+ } catch (error) {
146
+ console.log("objectAnalysis error", error);
147
+ }
148
+ },
149
+ methods: {
150
+ /**
151
+ * 标题点击事件
152
+ */
153
+ titleClick() {
154
+ if (this.isOpen) {
155
+ this.isOpen = false;
156
+ } else {
157
+ if (this.list.length == 0) {
158
+ this.analysisData(this.data);
159
+ }
160
+ this.isOpen = true;
161
+ }
162
+ },
163
+ /**
164
+ * 解析渲染数组
165
+ */
166
+ analysisData(data, pid = 0) {
167
+ let list = [];
168
+ let l = this.getParentNum(pid);
169
+
170
+ let keys = [];
171
+ keys = Reflect.ownKeys(data);
172
+
173
+ for (let i = 0; i < keys.length; i++) {
174
+ let key = keys[i];
175
+ let value = data[key];
176
+
177
+ if (key == "__proto__" || key == "__ob__") {
178
+ continue;
179
+ }
180
+
181
+ let o = {
182
+ t: typeof value,
183
+ k: key,
184
+ v: value,
185
+ vt: "",
186
+ i: randId(),
187
+ p: pid,
188
+ o: false,
189
+ l: l * 5,
190
+ d: value,
191
+ };
192
+
193
+ try {
194
+ let t = typeof value;
195
+ if (t == "function") {
196
+ try {
197
+ o.vt = value.toString();
198
+ } catch (error) {
199
+ if (error && error.message) {
200
+ o.vt = "[js:function]" + error.message;
201
+ } else {
202
+ o.vt = "[js:function]";
203
+ }
204
+ }
205
+ o.v = o.vt;
206
+ o.d = "";
207
+ } else if (t == "object") {
208
+ if (this.showObjProto) {
209
+ let str = "unknown";
210
+ if (value === null) {
211
+ o.t = "null";
212
+ str = "null";
213
+ } else if (Array.isArray(value)) {
214
+ o.t = "array";
215
+ let l = 0;
216
+ try {
217
+ l = value.length;
218
+ } catch (error) {}
219
+ str = Object.prototype.toString.call(value).slice(8, -1) + (l > 0 ? ` (${l})[...]` : " (0)[]");
220
+ } else {
221
+ o.t = "object";
222
+ let childList = [];
223
+ try {
224
+ childList = Reflect.ownKeys(value);
225
+ } catch (error) {}
226
+ str = Object.prototype.toString.call(value).slice(8, -1) + (childList.length == 0 ? " {}" : " {...}");
227
+ }
228
+ o.vt = str;
229
+ } else {
230
+ let type = getType(value);
231
+ let title = "";
232
+ try {
233
+ title = JSON.stringify(value);
234
+ if (title.length > 50) {
235
+ title = title.slice(0, 50) + "...";
236
+ }
237
+ if (type == "array" && value.length > 0) {
238
+ title = "(" + value.length + ")" + title;
239
+ }
240
+ } catch (error) {
241
+ title = "对象解析失败:" + error;
242
+ }
243
+ o.t = type;
244
+ o.vt = title;
245
+ o.v = value;
246
+ }
247
+ } else if (t == "symbol") {
248
+ o.t = "symbol";
249
+ try {
250
+ if (value.toString) {
251
+ o.vt = value.toString();
252
+ } else {
253
+ o.vt = "[js:symbol]";
254
+ }
255
+ } catch (error) {
256
+ let msg = "";
257
+ if (error && error.message) {
258
+ msg = error.message;
259
+ } else {
260
+ msg = "[js:symbol解析失败]";
261
+ }
262
+ o.vt = msg;
263
+ }
264
+ } else if (t == "string") {
265
+ if (value.length > 200) {
266
+ o.vt = `"` + value.slice(0, 200) + "..." + '"';
267
+ } else {
268
+ o.vt = `"${value}"`;
269
+ }
270
+ } else if (t == "number") {
271
+ if (Number.isFinite(value)) {
272
+ o.vt = value.toString();
273
+ } else {
274
+ o.vt = isNaN(value) ? "NaN" : "Infinity";
275
+ }
276
+ } else if (t == "boolean") {
277
+ o.vt = value ? "true" : "false";
278
+ } else if (t == "undefined") {
279
+ o.vt = "undefined";
280
+ } else {
281
+ o.vt = "[js:unknown type]";
282
+ }
283
+ } catch (error) {
284
+ let msg = "";
285
+ if (error && error.message) {
286
+ msg = error.message;
287
+ } else {
288
+ msg = "[js对象解析失败]";
289
+ }
290
+ o.vt = msg;
291
+ }
292
+ list.push(o);
293
+ }
294
+
295
+ if (pid == 0) {
296
+ this.list = list;
297
+ } else {
298
+ let faIndex = this.list.findIndex((x) => x.i == pid) + 1;
299
+ for (let i = 0; i < list.length; i++) {
300
+ this.list.splice(faIndex, 0, list[i]);
301
+ faIndex++;
302
+ }
303
+ }
304
+ },
305
+ /**
306
+ * 获取节点的父类数量
307
+ */
308
+ getParentNum(pid) {
309
+ let that = this;
310
+ let count = 0;
311
+ if (pid == 0) {
312
+ return count;
313
+ } else {
314
+ let p = Number(pid);
315
+ while (true) {
316
+ count = count + 1;
317
+ let fa = that.list.find((x) => x.i == p);
318
+ if (!fa || fa.i == 0) {
319
+ break;
320
+ } else {
321
+ p = Number(fa.p);
322
+ }
323
+ }
324
+ }
325
+ return count;
326
+ },
327
+ /**
328
+ * 行对象点击事件
329
+ */
330
+ rowClick(item, index) {
331
+ let that = this;
332
+ const nodeItem = that.list[index];
333
+ if (item.t == "object" || item.t == "array") {
334
+ if (item.o) {
335
+ nodeItem.o = false;
336
+ that.hideListByPid(item.i);
337
+ } else {
338
+ nodeItem.o = true;
339
+ that.analysisData(nodeItem.d, item.i);
340
+ }
341
+ } else if (item.t == "string" && item.v.length > 100) {
342
+ // 长文本点击时默认打开文本编辑器
343
+ uni.$emit("devTools_showTextEditDialog", {
344
+ title: item.k,
345
+ canSave: false,
346
+ isFileEdit: false,
347
+ value: item.v,
348
+ });
349
+ }
350
+ },
351
+ /**
352
+ * 根据父类id删除数组内元素
353
+ */
354
+ hideListByPid(pid = 0) {
355
+ let that = this;
356
+ while (true) {
357
+ let i = that.list.findIndex((x) => x.p == pid);
358
+ if (i == -1) {
359
+ break;
360
+ }
361
+ if (that.list[i].o) {
362
+ that.hideListByPid(that.list[i].i);
363
+ }
364
+ that.list.splice(i, 1);
365
+ }
366
+ },
367
+ /**
368
+ * 获取列表
369
+ */
370
+ getList() {
371
+ return this.list;
372
+ },
373
+ /**
374
+ * 获取父级key类别
375
+ */
376
+ getFaKeyList(itemId) {
377
+ let keyList = [];
378
+ let item = this.list.find((x) => x.i == itemId);
379
+ if (!item) return keyList;
380
+ keyList = [item.k];
381
+ if (item.p == 0) return keyList;
382
+
383
+ while (true) {
384
+ item = this.list.find((x) => x.i == item.p);
385
+ if (!item) break;
386
+ keyList.unshift(item.k);
387
+ if (item.p == 0) {
388
+ break;
389
+ }
390
+ }
391
+
392
+ return keyList;
393
+ },
394
+ /**
395
+ * 获取对象单行数据
396
+ */
397
+ getObjType(obj) {
398
+ try {
399
+ let title = "unknown";
400
+ let type = typeof obj;
401
+ let data = obj;
402
+ switch (typeof data) {
403
+ case "symbol":
404
+ title = "[js:symbol]";
405
+ try {
406
+ if (data.toString) {
407
+ title = data.toString();
408
+ } else {
409
+ title = "[js:symbol]";
410
+ }
411
+ } catch (error) {
412
+ let msg = "";
413
+ if (error && error.message) {
414
+ msg = error.message;
415
+ } else {
416
+ msg = "[js:symbol解析失败]";
417
+ }
418
+ title = msg;
419
+ }
420
+ break;
421
+ case "string":
422
+ title = data;
423
+ break;
424
+ case "object":
425
+ if (this.showObjProto) {
426
+ try {
427
+ let objType = Object.prototype.toString.call(data).slice(8, -1);
428
+ title = {};
429
+ let keys = Reflect.ownKeys(data);
430
+
431
+ for (let i = 0; i < keys.length; i++) {
432
+ let key = keys[i];
433
+ if (key == "__proto__" || key == "__ob__") {
434
+ continue;
435
+ }
436
+ try {
437
+ let value = data[key];
438
+ let t = typeof value;
439
+ if (t == "function") {
440
+ continue;
441
+ }
442
+ if (t == "object") {
443
+ let str = "unknown";
444
+ if (value === null) {
445
+ str = "null";
446
+ } else if (Array.isArray(value)) {
447
+ str = Object.prototype.toString.call(value).slice(8, -1) + " [...]";
448
+ } else {
449
+ str = Object.prototype.toString.call(value).slice(8, -1) + " {...}";
450
+ }
451
+ title[key] = str;
452
+ continue;
453
+ }
454
+ title[key] = data[key];
455
+ } catch (error) {
456
+ if (error && error.message) {
457
+ title[key] = error.message;
458
+ } else {
459
+ title[key] = "[js对象解析失败]";
460
+ }
461
+ }
462
+ }
463
+
464
+ for (let i = 0; i < keys.length; i++) {
465
+ let key = keys[i];
466
+ try {
467
+ let value = data[key];
468
+ let t = typeof value;
469
+ if (t == "function") {
470
+ try {
471
+ title[key] = value.toString();
472
+ } catch (error) {
473
+ if (error && error.message) {
474
+ title[key] = "[js:function]" + error.message;
475
+ } else {
476
+ title[key] = "[js:function]";
477
+ }
478
+ }
479
+ }
480
+ } catch (error) {
481
+ if (error && error.message) {
482
+ title[key] = error.message;
483
+ }
484
+ }
485
+ }
486
+ if (title.toJSON) {
487
+ title.toJSON = "[js:function]";
488
+ }
489
+
490
+ if (objType == "Array") {
491
+ title = objType + " " + jsonCompress.safeJsonStringify(title);
492
+ } else {
493
+ title = objType + " " + jsonCompress.safeJsonStringify(title);
494
+ }
495
+
496
+ if (Array.isArray(data)) {
497
+ type = "array";
498
+ } else {
499
+ type = "object";
500
+ }
501
+ } catch (error) {
502
+ let msg = "unknown";
503
+ if (error && error.message) {
504
+ msg = error.message;
505
+ }
506
+ title = "对象解析出错:" + msg;
507
+ }
508
+ } else {
509
+ try {
510
+ title = JSON.stringify(data);
511
+ if (title.length > 50) {
512
+ title = title.slice(0, 50) + "...";
513
+ }
514
+ } catch (error) {
515
+ title = "对象解析失败:" + error;
516
+ }
517
+ }
518
+
519
+ break;
520
+ case "function":
521
+ try {
522
+ title = data.toString();
523
+ } catch (error) {
524
+ title = "[js:function]";
525
+ }
526
+ break;
527
+ default:
528
+ title = data;
529
+ break;
530
+ }
531
+ return { title, type };
532
+ } catch (error) {
533
+ console.log("getObjType error", error);
534
+ return {
535
+ title: "unknown",
536
+ type: "unknown",
537
+ };
538
+ }
539
+ },
540
+ },
541
+ };
542
+ </script>
543
+ <style lang="scss" scoped>
544
+ .objectAnalysis {
545
+ display: flex;
546
+ flex-direction: column;
547
+ .objectTitle {
548
+ min-height: 40rpx;
549
+ padding: 4rpx 0;
550
+ display: flex;
551
+ flex-direction: row;
552
+ align-items: center;
553
+ .title {
554
+ font-size: 22rpx;
555
+ line-height: 32rpx;
556
+ color: #1e3a8a;
557
+ lines: 1;
558
+ overflow: hidden;
559
+ /* #ifdef H5 */
560
+ // 限制行数
561
+ display: -webkit-box;
562
+ -webkit-box-orient: vertical;
563
+ -webkit-line-clamp: 1;
564
+ /* #endif */
565
+ }
566
+ }
567
+ .objectTitleActive:active {
568
+ background-color: rgba(59, 130, 246, 0.08);
569
+ border-radius: 10rpx;
570
+ }
571
+ .objectList {
572
+ background-color: #f8fafc;
573
+ border: 1px solid rgba(148, 163, 184, 0.2);
574
+ border-radius: 12rpx;
575
+ /* #ifndef APP-PLUS */
576
+ min-height: 50rpx;
577
+ /* #endif */
578
+ padding: 10rpx 12rpx;
579
+ .listItem:active {
580
+ background-color: rgba(59, 130, 246, 0.08);
581
+ border-radius: 8rpx;
582
+ }
583
+ .listItem {
584
+ min-height: 36rpx;
585
+ display: flex;
586
+ flex-direction: row;
587
+ align-items: center;
588
+ .emptyFold {
589
+ width: 20rpx;
590
+ height: 20rpx;
591
+ margin-right: 6rpx;
592
+ }
593
+ .objKey {
594
+ font-size: 22rpx;
595
+ line-height: 32rpx;
596
+ color: #7c3aed;
597
+ lines: 1;
598
+ overflow: hidden;
599
+ /* #ifdef H5 */
600
+ // 限制行数
601
+ display: -webkit-box;
602
+ -webkit-box-orient: vertical;
603
+ -webkit-line-clamp: 1;
604
+ /* #endif */
605
+ }
606
+ .objValue {
607
+ line-height: 32rpx;
608
+ margin-left: 5rpx;
609
+ color: #333;
610
+ font-size: 22rpx;
611
+ lines: 1;
612
+ overflow: hidden;
613
+ /* #ifdef H5 */
614
+ // 限制行数
615
+ display: -webkit-box;
616
+ -webkit-box-orient: vertical;
617
+ -webkit-line-clamp: 1;
618
+ /* #endif */
619
+ &.t-number {
620
+ color: rgb(8, 66, 160);
621
+ }
622
+ &.t-boolean {
623
+ color: rgb(133, 2, 255);
624
+ }
625
+ &.t-string {
626
+ color: rgb(227, 54, 46);
627
+ }
628
+ &.t-array {
629
+ color: rgba(0, 0, 0, 0.5);
630
+ }
631
+ &.t-object {
632
+ color: rgba(0, 0, 0, 0.5);
633
+ }
634
+ &.t-undefined {
635
+ color: rgba(0, 0, 0, 0.2);
636
+ }
637
+ &.t-null {
638
+ color: rgba(0, 0, 0, 0.2);
639
+ }
640
+ }
641
+ }
642
+ }
643
+ }
644
+ .foldItem {
645
+ width: 22rpx;
646
+ height: 22rpx;
647
+ background-color: #e2e8f0;
648
+ border-radius: 4rpx;
649
+ margin-right: 6rpx;
650
+ }
651
+ </style>