@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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hlw-uni/mp-vue",
3
- "version": "1.1.17",
3
+ "version": "1.1.18",
4
4
  "description": "hlw-uni Vue 组件库 — 供小程序业务方使用的 UI 组件集合",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.mjs",
@@ -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
- /** 默认 slot 是否有非注释节点内容,用于避免空 slot 占位影响 flex 布局 */
89
- const hasContent = computed(() => {
90
- const nodes = slots.default?.();
91
- if (!nodes || nodes.length === 0) return false;
92
- return nodes.some((n) => {
93
- const type = n.type;
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> = {};