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