推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
phoenix0

js 变量无法进行调用

  •  
  •   phoenix0 · Dec 17, 2018 · 3733 views
    This topic created in 2713 days ago, the information mentioned may be changed or developed.

    window.onload = function() { alert('此 JS 代码可执行');

    var oWeib = document.getElementById('weib');
    var oCaid = document.getElementsByClassName('caid');
    var oA = document.getElementById('wb');
    
    function tan() {
    	alert(oA.getAttribute('href'));
    }
    
    oA.setAttribute = ("href","www.baidu.com");
    oA.onclick = tan();
    
    tan();
    

    }

    第一个 alert 和 tan()函数里的 alert 都会弹窗,但是后面的 set 就没有效果。 onclick 的点击事件也会被忽略然后直接触发 tan()函数。

    5 replies    2018-12-17 15:37:04 +08:00
    zjsxwc
        1
    zjsxwc  
       Dec 17, 2018   ❤️ 1
    oA.onclick = tan;
    shintendo
        2
    shintendo  
       Dec 17, 2018   ❤️ 1
    tan()是函数返回值,tan 才是函数
    linchengzzz
        3
    linchengzzz  
       Dec 17, 2018
    oA.onclick = () => tan(); 或者 oA.onclick = tan;
    lukunlin
        4
    lukunlin  
       Dec 17, 2018
    在 Js 里,记住,任何函数加()就是执行,除了.bind 一些特殊引向函数,然后你的函数没有写 return,那默认就是 return 的 undefined,所以你把一个函数执行的结果,undefined 复制给了一个 onevent,当然没效果
    beyoung
        5
    beyoung  
       Dec 17, 2018
    还以为是个大新闻呢
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   951 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 36ms · UTC 22:16 · PVG 06:16 · LAX 15:16 · JFK 18:16
    ♥ Do have faith in what you're doing.