How can I make a composable function with `weight` modifier?(如何使用`weight‘修饰符创建可组合函数?)
问题描述
当我有
Column {
Button(onClick = { /*TODO*/ },) {
Text("Original Window")
}
Button(onClick = { /*TODO*/ }) {
Text("Fit System Window")
}
}
我可以创建一个通用的可组合函数
@Composable
fun MyButton(
onClick: () -> Unit,
content: @Composable RowScope.() -> Unit
) {
Button(
onClick = onClick,
content = content
)
}
Column {
MyButton(onClick = { /*TODO*/ },) {
Text("Original Window")
}
MyButton(onClick = { /*TODO*/ }) {
Text("Fit System Window")
}
}
但是当我有
Column {
Button(onClick = { /*TODO*/ },
modifier = Modifier.weight(1f)) {
Text("Original Window")
}
Button(onClick = { /*TODO*/ },
modifier = Modifier.weight(1f)) {
Text("Fit System Window")
}
}
我无法在下面创建
@Composable
fun MyButton(
onClick: () -> Unit,
content: @Composable RowScope.() -> Unit
) {
Button(
onClick = onClick,
modifier = Modifier.weight(1f),
content = content
)
}
Column {
MyButton(onClick = { /*TODO*/ },) {
Text("Original Window")
}
MyButton(onClick = { /*TODO*/ }) {
Text("Fit System Window")
}
}
这是因为weight
修改量在ColumnScope
接口下。
如何使用weight
修饰符创建可组合函数?
推荐答案
看起来我只需要从ColumnScope
@Composable
fun ColumnScope.MyButton(
onClick: () -> Unit,
content: @Composable RowScope.() -> Unit
) {
Button(
onClick = onClick,
modifier = Modifier.weight(1f),
content = content
)
}
这篇关于如何使用`weight‘修饰符创建可组合函数?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!