+import { computed, ref } from '@vue/reactivity'
import { toDisplayString } from '../src'
describe('toDisplayString', () => {
expect(toDisplayString(arr)).toBe(JSON.stringify(arr, null, 2))
})
+ test('refs', () => {
+ const n = ref(1)
+ const np = computed(() => n.value + 1)
+ expect(
+ toDisplayString({
+ n,
+ np
+ })
+ ).toBe(JSON.stringify({ n: 1, np: 2 }, null, 2))
+ })
+
test('native objects', () => {
const div = document.createElement('div')
expect(toDisplayString(div)).toBe(`"[object HTMLDivElement]"`)
: String(val)
}
-const replacer = (_key: string, val: any) => {
- if (isMap(val)) {
+const replacer = (_key: string, val: any): any => {
+ // can't use isRef here since @vue/shared has no deps
+ if (val && val.__v_isRef) {
+ return replacer(_key, val.value)
+ } else if (isMap(val)) {
return {
[`Map(${val.size})`]: [...val.entries()].reduce((entries, [key, val]) => {
;(entries as any)[`${key} =>`] = val