如何解决在 mithril.js
我想在 mithril.js 中的 oninit
函数内设置一个属性。例如,
m('img',{
oninit: (vnode) => {
vnode.attrs.src = 'A url string';
}
})
我想在设置此属性之前检查某些条件,我宁愿不使用三元运算符,因为那样会变得混乱。上面的示例成功了一半,在记录 vnode
时,attrs
对象具有正确的 src
字符串,但是在 DOM 中,src
设置为 null
某种原因。
我正在寻找一个简单的解决方案,而不是像给元素一个 id
并用它来更改属性之类的东西。
解决方法
当使用闭包组件时,这些代码通常可以作为方法或函数放置在组件中。
这是在一个仅用于图像的组件中,但可以在直接呈现该 IMG 的父组件中完成此类工作。
function DynamicImg() {
function imageAttrs(vnode) {
let src = 'configurable';
return {src: src};
}
return {
view: function (vnode) {
return m('img',imageAttrs(vnode));
}
}
}
在 init 中设置 attr 不会持续,因为没有它会立即调用视图函数。因为它在每次渲染时都会被调用。
,对于任何寻求解决方案的人来说,这对我有用。
m('img',{
src: (() => {
return 'A url string';
})()
})
你可以在别处定义函数并调用它。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。