Jonckys
2018-09-21 04:51
采纳率: 100%
浏览 1.8k

【JavaScript】js中有时候调用方法使用引号,有时候不使用引号,这是为什么?

function showTime(){
var date=new Date();
var yyyy=date.getFullYear();
var MM=("0"+(date.getMonth()+1)).slice(-2);
var dd=("0"+date.getDate()).slice(-2);
var hh=("0"+date.getHours()).slice(-2);
var mm=("0"+date.getMinutes()).slice(-2);
var ss=("0"+date.getSeconds()).slice(-2);
var week=date.getDay();
var arr=["日","一","二","三","四","五"];
var time=yyyy+"年"+MM+"月"+dd+"日 星期"+arr[week]+" "+hh+":"+mm+":"+ss;
document.getElementById("time").innerText=time;
// setTimeout(showTime,1000); //这里不带引号直接需要去掉阔号,然后带引号的需要使用到括号,有点不解
setTimeout("showTime()",1000);
}


<!--Html代码块-->
<!--<body onload=showTime()>-->   //这里既可以用带引号的,也是不用   不理解地方A
    <body onload="showTime();">
    <div id="nav_head">
        <label  id="time" style="float: right; line-height: 40px; padding-right: 20px;">当前是时间:</label>
    </div>
    <script type="text/javascript" src="js/time.js" ></script>
</body>
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • 已采纳

    html中最好要用引号隔开,不用如果是复杂js代码包含引号会导致浏览器解析属性值出错而导致代码被截断而出错

    setTimeout是你没理解这个函数怎么用,第一个可以是函数,也可以是字符串格式js代码

    其他xxx.onxxx事件需要函数句柄,不能字符串
    window.onload=showTime()
    你这个也是有问题的,这个代码是执行showTime后将返回值(没有就默认返回undefined)作为window.onload的事件处理函数,所以实际window.onload一样无效,未执行

    已采纳该答案
    打赏 评论
  • smile_zls 2018-09-21 05:13

    都用引号就可以吧,有的可以 是不是浏览器的问题,它支持一些事件可以不加引号

    打赏 评论
  • Joker-Full-stack 2021-03-03 17:35

    最好是带引号,低版本的浏览器解析可能会出问题

    打赏 评论

相关推荐 更多相似问题