稍后在 html 文件中使用之前初始化 JavaScript class

Initializing JavaScript class before using it later in an html file

我有以下问题。我开发了一个 javaScript class 与 select 标签结合使用。由于 javaScript class 必须通过页面的 DOM 进行解析,我宁愿在 DOM 完成加载后初始化 class 而不一定是用户从 select 元素中选择一个值。我想知道执行此操作的最佳做​​法是什么。

我目前脑中有以下代码:

<script>
    window.addEventListener('DOMContentLoaded', (event) => {
  
      // As soon as DOM content is loaded initialize class and have class parse through DOM     
      obj = new Object();
      
    });
</script>

和下面的 select 在正文中:

<select name="select" id="select" onChange="obj.function(this);">
    <option value="value1">Value1</option>
    <option value="value2">Value2</option>
</select>   

但是,当我 运行 这样做时,我得到了 obj 的未捕获引用错误。这方面的最佳做法是什么?

您应该在该文档准备好使用新实例后绑定 select 事件 onChange。

<script>
    window.addEventListener('DOMContentLoaded', (event) => {
  
      // As soon as DOM content is loaded initialize class and have class parse through DOM     
      obj = new Object();
      sel = document.getElementById('select')
      sel.onChange = obj.function(sel)
    });
</script>

...

<select name="select" id="select">
    <option value="value1">Value1</option>
    <option value="value2">Value2</option>
</select>