首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > JavaScript >

js 赋值有关问题

2012-10-11 
js 赋值问题HTML code!DOCTYPE html PUBLIC -//W3C//DTD XHTML 1.0 Transitional//EN http://www.w3.o

js 赋值问题

HTML code
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>百度输入法</title><style>body,ul,li,button{margin:0;padding:0;}body{font:12px/1.5 Tahoma;}ul{list-style-type:none;}button{cursor:pointer;}#outer{width:70px;margin:10px auto;}#ime{margin-top:5px;background:#fff;border:1px solid #9a99ff;display:none;}#ime li{width:100%;line-height:24px;display:inline-block;vertical-align:top;}#close{border-top:1px solid #9a99ff;}#ime li a{color:#00c;padding:0 5px;display:block;text-decoration:none;}#ime li a:hover{background:#d9e1f6;}</style><script>window.onload = function (){    var oBtn = document.getElementsByTagName("button")[0];    var oIme = document.getElementById("ime");    var oClose = document.getElementById("close");         var style = oIme.style;    oBtn.onclick = function()    {                style.display = style.display == "block" ? "none" : "block"    };    oClose.onclick = function()    {        style.display = "none"        }}</script></head><body><div id="outer">    <button>输入法</button>    <ul id="ime">        <li><a href="javascript:;">手写</a></li>        <li><a href="javascript:;">拼音</a></li>        <li id="close">关闭</li>    </ul></div></body></html>


这里的js为什么只能写
“style.display = style.display == "block" ? "none" : "block"


而不能直接写成


“style.display = "block" ? "none" : "block"


[解决办法]
改成这样是不是明显一些? style.display = ((style.display == "block") ? "none" : "block"),这句话目的是隐藏/显示的切换。
[解决办法]
style.display = style.display == "block" ? "none" : "block"
相当于style.display = (style.display == "block" ? "none" : "block");
style.display == "block" ? "none" : "block";这是一个判断语句,结果为"none"或"block"
然后赋值给style.display
而style.display = "block" ? "none" : "block"这句话中没有精确判断
"block"?"none":"block";这句话只是判断"block"永远为真
而不能判断div是否为显示
判断字符串一定要用==的

热点排行
Bad Request.