1

我正在尝试通过迭代一个集合来使用 kotlinx.html 构建一个 HTML 列表,对于集合中的每个元素,我想在 UL 标记内构建一个 LI 标记。

这就是我正在尝试的:

fun showProducts(products: List<Product>) {
    document.getElementById(content.id)
        ?.append {
            ol {
                products.forEach {
                    this.li {
                        +it.name
                    }
                }
            }
        }
}

但是我在浏览器控制台中收到错误:

Uncaught (in promise) TypeError:closure$products.iterator is not a function

如何迭代集合并在 UL 标签内为传递给函数的每个产品添加 LI 标签?

4

1 回答 1

0

也许,products.forEach您可以使用简单的for (p in products). 所以代码将是:

fun showProducts(products: List<Product>) {
    document.getElementById(content.id)
        ?.append {
            ol {
                for (p in products) {
                    li {
                        +p.name
                    }
                }
            }
        }
}

看到这个链接: https ://try.kotlinlang.org/#/Kotlin%20Koans/Builders/Html%20builders/Task.kt

于 2020-07-04T23:11:47.263 回答