web-dev-qa-db-ja.com

jQueryを使用しないOnClick

onclickの作成方法なし jQuery、HTMLの追加コードなし、など:

<a href="#" onclick="tramtramtram">

外部のjsファイルを使用していますか?

<script type="text/javascript" src="functions.js"></script>

このコードを置き換える必要があります:

$("a.scroll-up, a.scroll-down").click(function(){
    SNavigate($(this).attr("href").substr(7));return false;
});
46
Mike

このアンカーにクリック時に処理する関数が1つだけ含まれる場合、次のように書くことができます。

document.getElementById('anchorID').onclick=function(){/* some code */}

それ以外の場合は、DOMメソッドaddEventListenerを使用する必要があります

function clickHandler(){ /* some code */ }
var anchor = document.getElementById('anchorID');
if(anchor.addEventListener) // DOM method
  anchor.addEventListener('click', clickHandler, false);
else if(anchor.attachEvent) // this is for IE, because it doesn't support addEventListener
   anchor.attachEvent('onclick', function(){ return clickHandler.apply(anchor, [window.event]}); // this strange part for making the keyword 'this' indicate the clicked anchor

また、すべての要素がロードされたときに上記のコードを呼び出すことを忘れないでください(たとえば、window.onloadで)

-編集

詳細を追加しました。以下のコードを置き換える場合

$("a.scroll-up, a.scroll-down").click(function(){SNavigate($(this).attr("href").substr(7));return false;});

jQueryを使用しないsthで、これは仕事をするはずです

function addEvent(obj, type, fn) {
        if (obj.addEventListener)
                obj.addEventListener(type, fn, false);
        else if (obj.attachEvent)
                obj.attachEvent('on' + type, function() { return fn.apply(obj, [window.event]);});
}
addEvent(window, 'load', function(){
   for(var i=0, a=document.anchors, l=a.length; i<l;++i){
      if(a[i].className == 'scroll-up' || a[i].className == 'scroll-down'){
         addEvent(a[i], 'click', function(e){ SNavigate(this.href.substr(7)); e.returnValue=false; if(e.preventDefault)e.preventDefault();return false});
      }
   }
});
60
Rafael

これはどう :

document.getElementById("lady").onclick = function () {alert('onclick');};
13
Canavar

W3Cの提案:

element.addEventListener('click',doSomething,false)

マイクロソフトは以下を使用します。

element.attachEvent('onclick',doSomething)

いくつかの機能検出を行い、使用する呼び出しを決定できます。

http://www.quirksmode.org/js/events_advanced.html から。

5
Corbin March

Htmlに余分なコードがないので、これを行う方法を次に示します。

<html><body><head><script>  // This script could be in an external JS file
function my_handler(elt) {
    alert("Yay!");
    return false;
}

function setup() {
    document.getElementById('lady').onclick = my_handler;
}

window.onload = setup;
</script></head>
<body><a href='#' id='lady'>Test</a></body>
</html>
2
RichieHindle
<script>
 function tramtramtram(){
     alert("tram it!");
 }
</script>


<a href="#" onclick="tramtramtram()">tramtram</a>
1
bchhun

var el = document.getElementById( 'lady'); el.addEventListener( "click"、tramtramtram、false);

1
ka3751

ドキュメントが読み込まれたときにこのスクリプトを実行します(アラートを自分のものに置き換えます):

var rgLinks = document.getElementsByTagName("A");

for (var x=0; x<rgLinks.length; x++) {
    el = rgLinks[x];

    if (el.className == 'scroll-down' || el.className == 'scroll-down')
        {
        el.onclick = function () {alert('onclick');};
        }
    }

たぶんそれはあなたが尋ねているものです...

1
buti-oxa

onclick 属性を使用するだけです。

<a href="#" onclick="functionName(someParam)">

または、javascriptから実行するには、

document.getElementById("anchorID").onclick = function(){
   some code
};
0
null

Onclickハンドラーを追加するには、getElementByIdを使用する必要があります。ただし、どこかでコードを開始する必要があります。 jQueryなしでは、body onloadハンドラーのみを使用できます。

<body onload="myinitfunction()">

myinitfunctionは、外部jsファイルに含めることができます。

0
kgiannakakis