2017-12-19 7 views
0

jQueryを使用してJavaScriptを学習し始めています。p値==文字列が機能しない場合

私は、次のコードを持っている:

$(document).ready(function(){ 
 
    $("#p1").click(function(){ 
 

 
     var input = document.getElementById("p3"); 
 

 
     if (input.value == "Hi") 
 
     { 
 
      message = "Bye"; 
 
     } else { 
 
      message = "Hi"; 
 
     } 
 

 
     $("#p3").text(message); 
 
    }); 
 

 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div id="div1"> 
 

 
    <p id="p1">Click on me.</p> 
 
    <p id="p2">Click on me again.</p> 
 
    <p id="p3">Click on me one more time.</p> 
 

 
</div> 
 

それは、P1の最初のクリックで動作しますが、私はもう一度クリックしたとき、それは

+0

を示すfalseを返します私は(場合 'input.valueを変更するには、あなたをお勧めします== "Hi") 'if(input.value ===" Hi ")' – assembler

答えて

3

"さようなら" に変更されません。それはpアラグラフであり、inputではないので、.valueは必要なものを提供していません。代わりに.textContentを使用してください。

$(document).ready(function() { 
 
    $("#p1").click(function() { 
 

 
    var input = document.getElementById("p3"); 
 

 
    if (input.textContent == "Hi") { 
 
     message = "Bye"; 
 
    } else { 
 
     message = "Hi"; 
 
    } 
 

 
    $("#p3").text(message); 
 
    }); 
 

 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div id="div1"> 
 

 
    <p id="p1">Click on me.</p> 
 
    <p id="p2">Click on me again.</p> 
 
    <p id="p3">Click on me one more time.</p> 
 

 
</div>


ここで無jQueryのバージョンです:一貫性の便宜上

document.addEventListener("DOMContentLoaded", function() { 
 
    document.querySelector("#p1").addEventListener("click", function() { 
 
    var p3 = document.getElementById("p3"); 
 
    p3.textContent = p3.textContent == "Hi" ? "Bye" : "Hi"; 
 
    }); 
 
});
<div id="div1"> 
 
    <p id="p1">Click on me.</p> 
 
    <p id="p2">Click on me again.</p> 
 
    <p id="p3">Click on me one more time.</p> 
 
</div>

+1

ありがとう! – Stordon

0

、私がいただきたいjQueryを使ってP3のアップを見て、 text()メソッドをオフにするそれ。入力値が故に未定義であるため、if (input.value == "Hi")そもそも

$(document).ready(function(){ 
 
    var $p3 = $('#p3'); 
 
    
 
    $("#p1").click(function(){ 
 
     var message = "Hi"; 
 
     
 
     if ($p3.text() === "Hi") message = "Bye"; 
 

 
     $p3.text(message); 
 
    }); 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div id="div1"> 
 

 
    <p id="p1">Click on me.</p> 
 
    <p id="p2">Click on me again.</p> 
 
    <p id="p3">Click on me one more time.</p> 
 

 
</div>

0

は常に常に「こんにちは」

関連する問題