笔试题整理(七)

完美世界

一、input标签事件

1.onfocus 当input 获取到焦点时触发
2.onblur 当input失去焦点时触发,注意:这个事件触发的前提是已经获取了焦点再失去焦点的时候会触发相应的js

3.onchange 当input失去焦点并且value值发生变化时触发

4.onkeydown 在 input中有键按住的时候执行一些代码

5.onkeyup 在input中有键抬起的时候触发的事件,在此事件触发之前一定触发了onkeydown事件

6.onclick 主要是用于 input type=button,当被点击时触发此事件

7.onselect 当input里的文本内容被部分选中或全部选中后触发

8.oninput 当input的仅value值发生变化时就会触发,不用等到失去焦点(与onchange的区别)

参考文献:
input 标签的监听事件总结

二、严格模式的限制

1、禁止不标准的全局变量(未使用var)
2、禁止使用with语句
3、禁止使用eval
4、禁止this关键字指向全局对象
5、禁止在函数内部遍历调用栈
6、禁止删除变量
7、对象不能有重命名属性
8、函数不能有重命名参数
9、禁止8进制表示法
10、不能对arguments赋值
11、arguments不再追踪参数的变化
12、禁止使用arguments.callee
13、只允许在全局作用域或函数作用域的顶层声明函数。也就是说不允许在非函数的代码块内声明函数。
14、不能使用某些保留字:implements,interface,let,package,private,protected,public,static,yield。

参考文献:
JS严格模式的限制

三、viewport

格式:

<meta name="viewport" content="width=device-width;initial-scale=1.0;maximum-scale=1;user-scalable=no;">

相关属性:



一般情况下为了自适应布局,通常将width设置为device-width。

参考文献:
说说移动前端中 viewport (视口)

四、css中可以继承的属性

1、字体系列属性
font
font-family
font-weight
font-size
font-style
font-variant
font-stretch
font-size-adjust
2、文本系列属性
text-indent
text-align
line-height
word-spacing
letter-spacing
text-transform
direction
color
3、元素可见性
visibility
4、表格布局属性
caption-side
border-collapse
border-spacing
empty-cells
table-layout
5、列表布局属性
list-style-type
list-style-image
list-style-position
list-style
6、生成内容属性
quotes
7、光标属性
cursor
8、页面样式属性
page
page-break-inside
windows
orphans
9、声音样式属性
speak
speak-punctuation
speak-numeral
speak-header
speech-rate
family
pitch
pitch-range
stress
richness
azimuth
elevation

参考文献:
CSS中可以和不可以继承的属性

五、video不支持的编码格式

不支持MP4格式

补充:
1、video支持的编码格式
①IE9:H.264和vp8
②Firefox 4以上:Ogg Theora和vp8
③Opera 10以上:Ogg Theora和vp8
④Chrome 6以上:H.264、OggTheora和vp8
2、audio支持的编码格式
①IE9:MP3和WAV
②Firefox 4以上:Ogg vorbis和WAV
③Opera 10以上:Ogg vorbis和WAV
④Chrome 6以上:Ogg vorbis和MP3

参考文献:
《HTML5与CSS3权威指南》

六、调用外部css文件的方法有哪些?link和@import的区别?

Q1:
1、使用link标签引入外部CSS文件

<head>
<link rel="stylesheet" href="css文件.css" type="text/css" media="all"/>
</head>

2、使用@import引入外部的css文件

<style type="text/css" media="screen">
@import url("css文件");
</style>

Q2:
区别:
①link是XHTML标签,除了加载CSS外还可以定义RSS等其他事务;@import属于CSS范畴,只能加载CSS。
②link引用CSS时,在页面载入时同时加载;@import需要页面完全载入以后加载
③link是XHTML标签,无兼容性问题;@import是在CSS2.1中提出的,低版本浏览器不支持。
④link支持用JavaScript控制DOM去改变样式,而@import不支持。

七、HTML全局属性

八、js键盘鼠标事件

1、onKeydown:用户按下按键时触发
2、onKeypress:用户敲击按钮时触发
3、onKeyup:用户从按键上抬起

九、使用以下结构

<div id="box" style="width:1000px;height:1000px;position:relative;overflow: hidden;">
<div id="ball" style="width: 10px;height: 10px;border-radius: 5px;position:absolute;background:red;"></div>
</div>
请用js写一个方法,这个方法实现:
1、id为ball的小球在id为box的框内出现位置随机,并具有初始速度v/秒,且方向随机;
2、小球碰到框的边缘时,以折现形式回弹(入射角等于反射角);

分析:

1、出现位置随机。只要使小球的初始left值和top值为框内范围的随机值(box.offsetWidth-ball.offsetWidth)Math.random()和(box.offsetHeight-ball.offsetHeight)Math.random(),
2、初始速度为v,方向随机。可以通过随机生成弧度角度theta=2Math.PIMath.random(),并利用Math.sin()和Math.cos()对初始速度v在x轴方向和y轴方向分解。
3、入射角等于反射角。若小球在x轴方向上碰到边框,则将x轴速度取反,y轴速度保持不变;如果小球在y轴方向上碰到边框,则将y轴速度取反,y轴速度保持不变。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>randomBall</title>
    <script>
        window.onload=function(){
            var box=document.getElementById("box");
            var ball=document.getElementById("ball");
            //定义小球初始top和left值
          var ballX=(box.offsetWidth-ball.offsetWidth)*Math.random();
          var ballY=(box.offsetHeight-ball.offsetHeight)*Math.random();
          ball.style.left=ballX+'px';
          ball.style.top=ballY+'px';
          //定义小球速度
          var speed=2;
          var theta=2*Math.PI*Math.random();
          var speedX=speed*Math.cos(theta);
          var speedY=speed*Math.sin(theta);
         setInterval(function(){
             //更新小球当前坐标
             ballX+=speedX;
             ballY+=speedY;
             //如果小球出界了,速度反向
             if(ballX+ball.offsetWidth>=box.offsetWidth||ballX<=0){
                 speedX=-speedX;
             }
             if(ballY+ball.offsetHeight>=box.offsetHeight||ballY<=0){
                 speedY=-speedY;
             }
             ball.style.left=ballX+'px';
             ball.style.top=ballY+'px';;
         },10);

        };
    </script>
</head>
<body>
<div id="box" style="width:1000px;height:1000px;position:relative;overflow: hidden;border:1px solid black;">
<div id="ball" style="width: 10px;height: 10px;border-radius: 5px;position:absolute;background:red;"></div>
</div>
</body>
</html>

十、

以下代码的执行结果

 var timeout=setTimeout(function(){
                console.log(1);
            },0);
            clearTimeout(timeout);

分析:这段代码不会打印1,因为setTimeout是把事件加入到事件队列中,会优先执行完主线程的代码,这时候就把定时器清除了。

十一、

以下代码的执行结果

            var a=0;
            var b=2;
            a=b+++5*++b;
            console.log(a);

分析:在js中++ --的优先级高于* / %,高于+ -,同等优先级按照从左向右顺序执行
因此第三句相当于

a=(b++)+5*(++b)

,执行b++时,b的值为2,执行完b++,b变成3,执行到++b的时候,b变成4,所以有

a=2+5*4=22
补充:

参考文献:
JavaScript中运算符的优先级

十二、

以下代码的执行结果

console.log(1+"2");

分析:
“12”
分析:本题涉及加性操作符“+”的用法。
如果有一个操作数是字符串,加性操作符的执行规则如下:
①如果两个操作数都是字符串,则将第二个操作数与第一个操作数拼接起来。
②如果只有一个操作数是字符串,则将另一个操作数转换为字符串,然后再将两个字符串拼接起来。
③如果有一个操作数是对象、数值、布尔值,则调用它们的toString()方法取得相应的字符串值,然后再应用前面关于字符串的规则。对于null和undefined,则分别调用String()函数并取得字符串“undefined”和“null”。

参考文献:
JavaScript高级程序设计(第三版)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,741评论 1 92
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,737评论 0 2
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,306评论 0 11
  • 如果评选德国最具人气的快餐,什么肯德基、麦当劳通通靠边站,土耳其卷饼才是扛把子。 土耳其卷饼,德语里被称为Döne...
    向日葵的阅宝宝阅读 4,369评论 2 6