@hlw-uni/mp-vue 1.1.17 → 1.1.18
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.
package/package.json
CHANGED
|
@@ -85,23 +85,12 @@ const emit = defineEmits<{ click: [] }>();
|
|
|
85
85
|
const slots = useSlots();
|
|
86
86
|
const hasIcon = computed(() => Boolean(props.icon || slots.icon));
|
|
87
87
|
|
|
88
|
-
/**
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
// 普通元素 / 组件节点
|
|
95
|
-
if (typeof type !== "symbol") return true;
|
|
96
|
-
// symbol 类型的节点(Comment / Fragment / Text),通过 description 判断
|
|
97
|
-
const desc = String((type as unknown as { description?: string }).description || "");
|
|
98
|
-
if (desc.includes("Comment") || desc === "v-cmt") return false;
|
|
99
|
-
// Text / Fragment 节点:有实际 children 才算有内容
|
|
100
|
-
if (typeof n.children === "string") return n.children.trim() !== "";
|
|
101
|
-
if (Array.isArray(n.children)) return n.children.length > 0;
|
|
102
|
-
return false;
|
|
103
|
-
});
|
|
104
|
-
});
|
|
88
|
+
/**
|
|
89
|
+
* 默认 slot 是否有内容,用于避免空 slot 占位影响 flex 布局。
|
|
90
|
+
* 小程序 Vue runtime 的 VNode 结构与标准 Vue 不同,这里仅检测 slot 函数是否存在 —
|
|
91
|
+
* `<hlw-button />` 自闭合时 slots.default 为 undefined;有任何 slot 内容(含 `<hlw-button></hlw-button>` 之外)时为函数。
|
|
92
|
+
*/
|
|
93
|
+
const hasContent = computed(() => Boolean(slots.default));
|
|
105
94
|
|
|
106
95
|
const buttonStyle = computed(() => {
|
|
107
96
|
const style: Record<string, string> = {};
|