I have the code below. I would like to have an array (buttons) with a single element pointing to the a function (closeFlag).
<script type="text/javascript">
    var closeFlag = new function() {
        alert('Clicked');
    }
    var buttons = {
        'OK': closeFlag
    }
</script>
However, when loading the page the alert immediately pops up. When the array is constructed, instead of usin开发者_StackOverflow中文版g it as a pointer, JavaScript calls my function. Why? What mistake, misconception do I have?
The new keyword, you will not need it.
<script type="text/javascript">
  var closeFlag = function() {
    alert('Clicked');
  }
  var buttons = {
    'OK': closeFlag
  }
</script>
What's happening in your code is that it's constructing the anonymous function then assigning the result of it (this) to closeFlag.
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论