在控制器中我有
init(){
this._super(...arguments);
document.body.classList.add("darkMode");
document.getElementById('mode').src = 'assets/images/logo-white'
}
在车把中:
<img id="mode" src="assets/images/logo-black.png" alt="white-theme" width="188px" height="56px">
当我尝试在我的项目中应用一个黑暗主题时,我成功地添加了这个类,但是当我试图通过查找其id来更改logo img src时,它崩溃了(因为没有任何东西显示了),这可能是因为**init()**在加载实际图像之前做了所有的事情,并且不能从img中获取id。我还没有解决这个问题的方法,所以任何想法都很棒。
- 我这样做只是为了测试,稍后我将添加一个if子句来测试用户是否希望启用暗模式 *
1条答案
按热度按时间ldxq2e6h1#
正确。任何组件示例的
init
挂钩都将在正确构造组件的DOM(模板)之前执行,因此我们此时无法访问DOM。您可以将所有与DOM相关的逻辑移到组件的另一个生命周期挂钩didInsertElement
中,该挂钩仅在构造DOM之后调用。This twiddle应该会对您有所帮助!
但是,建议将模板设置为声明性的,而不是手动更新DOM,以避免意外的错误。
因此更改状态
isDarkTheme
就足以跟踪所有相关的DOM/UI片段。