看了牛人写的回忆文章,里面有2010年腾讯的前端面试题,里面涉及到不少基础性的问题,js部分已学习,这是jquery,html和css部分,学习一下:)

原文地址:https://segmentfault.com/a/1190000012998107

jQuery部分:

  1. jQuery里如何绑定事件?有多少种方式?
  2. jQuery绑定事件时,this指针指向的是?(dom对象还是jQuery对象)
  3. 对于页面中暂时不存在的对象,如果进行事件绑定?
  4. 为什么选用jQuery框架(言下之意就是还有哪些其他的框架,各有什么优缺点,即你对比之后选择的原因)
  5. 有没有考虑过jQuery UI?如何对jQuery UI的样式进行定制?
  6. 有没有自己写作jQuery插件(即如何写jQuery插件)

1.1)个人最常用的使用a.click(function(){})这样的方式,这其实是bind(type,[data],function(eventObject))方式的简写,它的缺点只能为页面已经加载好的元素绑定事件,不能绑定动态添加的元素。适用版本<jquery3.0;

2)live(type, [data], fn)。这个方法看似和bind一样,其实实现大不一样。他是利用事件委托机制将click事件注册到document上。这样使得他可以给动态添加的元素绑定事件。缺点主要是不支持event.stopPropogation(),阻止冒泡的操作。 适用版本<jquery1.7;

3)delegate( selector, types, [data], fn )。这个方法同样是利用事件委托机制,但是是将click事件注册到你指定的附加元素上(一般你可以注册到父元素上)。如:

$( "#members" ).delegate( "li a", "click", function( e ) {} );//members只要为"li a"的父节点即可

这个方法稍复杂,但也没有明显的缺点,但是jquery的新版本把它的功能到新的方法on()中了。适用版本<jquery1.7。

4)on()。on方法合并了以上3种方法。而它的具体实现方式,将根据你的调用方法来决定。参考代码:

 /* Jquery的 .bind() , .live() 和 .delegate() 方法只需要使用`.on()`方法一种方式来调用它们 */

 // Bind
$( "#members li a" ).on( "click", function( e ) {} );
$( "#members li a" ).bind( "click", function( e ) {} ); // Live
$( document ).on( "click", "#members li a", function( e ) {} );
$( "#members li a" ).live( "click", function( e ) {} ); // Delegate
$( "#members" ).on( "click", "li a", function( e ) {} );
$( "#members" ).delegate( "li a", "click", function( e ) {} );

很明显,on()方法提供了对Bind和Delegate方法的兼容,这也是jquery的作者提倡使用的方法。缺点是可能给初次使用的人一些困惑。与之配套的是,使用.off(event,selector,function(eventObj),map)方法可以解绑事件。适用版本>=jquery1.7。

参考文章:http://www.jb51.net/article/120018.htm

2. this指向dom对象,如果是$(this),则转化为jquery对象。

3.如前所述,对于页面中暂时不存在的对象,可以使用live(),delegate(),on()绑定。在jquery1.7以下使用live(),delegate;jquery1.7及以上推荐使用on()绑定。

4.我个人最开始编写前端代码的时候,在面临选择框架的时候,就选用了jquery。jquery的优点:1)文件较小,压缩后只有10几k;2)使用者广泛,随处可见大量使用jquery的网站,以及各种jquery开发的插件,这对开发的帮助是极大的;3)兼容性好。jquery2.0之前的版本都兼容ie6浏览器,对各其他浏览器的兼容性也非常不错。4)语法直观,很容易上手。例如标签选择器,通过$("")就能准确找到dom进行操作;click事件则直接可以使用$("").click(function(){}),和原生js中的onclick相似,非常直观。

其他的前端框架有:extjs--富客户端框架,收费,外观漂亮;angularjs-比较笨重,有一些兼容性问题等。这些框架我很少使用,也是知道些皮毛,主要还是使用jquery多。

基于jquery的框架,我还使用过semantic UI框架。他里面有一些非常方便实用的功能(比如弹出层,按钮样式,文本框验证等),虽然对于开发大型网站的前端不太适合,但是对于开发cms管理后台则是非常方便的。

5.jquery UI 是以 jQuery 为基础的开源 JavaScript 网页用户界面代码库。包含底层用户交互、动画、特效和可更换主题的可视控件。我们可以直接用它来构建具有很好交互性的web应用程序。所有插件测试能兼容IE 6.0+, Firefox 3+, Safari 3.1+。

jqueryUI类似于semanticUI,虽然对于开发大型网站的前端不太适合,但是对于开发cms管理后台则是非常方便的。jqueryUI的定制,一是可以填写选项,使得插件按指定方式运行;二是可以去编写主题或去专业网站定制主题。参考:http://www.jqueryui.org.cn/tutorial/31.html。

6.没有编写过jquery插件,不过改写过一些jquery的插件(自动填充输入框默认文字,轮转图插件等)。

jquery插件一般会用闭包,格式如下:

(function($){
//插件书写部分
})(jQuery);

  参考:https://blog.csdn.net/qq_18661257/article/details/50434475

---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

html+CSS:

  1. 用html+CSS实现这样的布局效果,左栏固定宽度,右栏宽度自适应并填满剩下空间。
  2. 说说<strong>标签和<b>标签的区别,如果让你选择,你会选择使用哪个?
  3. 说说你对对html标签语义化的理解。

1.方法有两种:1)左栏float:left,右栏margin-left:左栏宽度;2.左栏采用绝对定位,右栏还是margin-left:左栏宽度。参考:https://blog.csdn.net/wky_csdn/article/details/72475481

2.<strong>和<b>在页面表现上都是加粗字体。区别是一个字符,一个六个字符。<b>对应bold,单纯的表示加粗;<strong>有强调,重点指出的意味,为了达到这个目的,加粗显示。我选择的话,如果只是加粗,会选择利用css属性font-weight:bold来实现,如果是要强调的话,会使用<strong>。

3.标签语义化的目的是使得页面对应的部分用正确语义标签来表示,可以使得页面内容结构化,便于浏览器解析,便于搜索引擎解析,增加页面可读性和可维护性。所以尽量减少使用<div>,<span>等没有语义的标签,多使用<header><article><section>等标签来表示。

2010年腾讯前端面试题学习(jquery,html,css部分)的更多相关文章

  1. 2010年腾讯前端面试题学习(js部分)

    看了牛人写的回忆文章,里面有2010年腾讯的前端面试题,里面涉及到不少基础性的问题,学习一下:) 原文地址:https://segmentfault.com/a/1190000012998107 js ...

  2. 2019届校招前端面试题整理——HTML、CSS篇

    前言 2019届校招陆陆续续开始了,整理了一些高频的面试题. HTML部分 1. 什么是<!DOCTYPE>? DOCTYPE是html5标准网页声明,且必须声明在HTML文档的第一行.来 ...

  3. 前端面试题之Html和CSS

    又到了毕业季,很多小伙伴们都到了找工作的时候了,好多小伙伴问我有前端的面试题么?答:没有. 呃呃… … 小伙伴本宝宝真的没有骗你们,我从毕业到现在一直在一家公司没有换过,所以手里压根没有面试题.我们公 ...

  4. 总结一下前端面试题之Html和CSS

    总结一下关于前端的面试题,今天我们分享关于Html和CSS部分的 面试 (1) 1. 常用那几种浏览器测试?有哪些内核(Layout Engine)? 2. 说下行内元素和块级元素的区别?行内块元素的 ...

  5. 前端面试题(HTML、CSS部分)

    HTML.CSS部分: 一.html5有哪些新特性.移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?   新特性: HTML5 现在已经不是 SGML 的 ...

  6. 前端面试题整理—jQuery篇

    1.为什么使用jquery,他有哪些好处? 1)轻量级.代码简洁 2)强大的选择器,出色的DOM操作封装 3)有可靠的事件处理机制 4)浏览器兼容性好 5)支持链式操作 6)支持丰富的插件 2.jqu ...

  7. 前端面试题 之 JavaScript

    昨天我们一起分享了关于html和css的面试题<前端面试题之Html和CSS>,今天我们来分享关于javascript有关的面试题.我面试的时候最害怕面试官问我js了,因为我真心不擅长这个 ...

  8. 史上最全前端面试题(含答案)-A篇

    HTML+CSS1.对WEB标准以及W3C的理解与认识标签闭合.标签小写.不乱嵌套.提高搜索机器人搜索几率.使用外 链css和js脚本.结构行为表现的分离.文件下载与页面速度更快.内容能被更多的用户所 ...

  9. 金三银四,磨砺锋芒;剑指大厂,扬帆起航(2020年最全大厂WEB前端面试题精选)上

    金三银四,磨砺锋芒:剑指大厂,扬帆起航(2020年最全大厂WEB前端面试题精选)上 引言 元旦匆匆而过,2020年的春节又接踵而来,大家除了忙的提着裤子加班.年底冲冲冲外,还有着对于明年的迷茫和期待! ...

随机推荐

  1. yii框架中获取添加数据后的id值

    Yii::$app->db->createCommand()->insert('month4_user',['openid'=>$openid,'integ'=>0])- ...

  2. vm15安装MACOS

    VMWare15 安装 Mac OS 系统文章目录VMWare15 安装 Mac OS 系统安装环境工具准备准备工作MAC虚拟机设置启动MAC前准备工作安装系统安装VMware Tool注意事项参考链 ...

  3. 海康摄像头配置固定IP

    前言 首先要海康设备连接好网线,电脑客户端跟海康设备在同一个局域网络. 1.直接在海康网站下载SADP工具软件,安装SADP工具,如图所示: 2.安装成功后,桌面的出现设备网络搜索, 面板介绍:这里将 ...

  4. 『TensorFlow』SSD源码学习_其四:数据介绍及TFR文件生成

    Fork版本项目地址:SSD 一.数据格式介绍 数据文件夹命名为VOC2012,内部有5个子文件夹,如下, 我们的检测任务中使用JPEGImages文件夹和Annotations文件夹. JPEGIm ...

  5. python-flask-SQLAlchemy-Utils组件

    SQLAlchemy-Utils,提供choice功能 定义: # pip3 install sqlalchemy-utils from sqlalchemy_utils import ChoiceT ...

  6. MySQL-1236问题处理

      2018年9月26日 9:25 现象:192.168.7.206.192.168.7.207互为双主,同步报错  1236   7.206现象如下 root@mysqldb 09:15  [mys ...

  7. bootstrap table导出功能无效报错Uncaught INVALID_CHARACTER_ERR: DOM Exception 5和导出中文乱码问题

    由于表格数据中含有中文导致的,在网页的开发者选项中报一个 Uncaught INVALID_CHARACTER_ERR: DOM Exception 5 问题.这个问题是由于BootStrap tab ...

  8. Node.js + Express 接口请求(GET、POST、PUT)事例

    路由 路由是指应用程序的端点(URI)如何响应客户端请求.有关路由的介绍,请参阅基本路由. 您可以使用Express app对象的方法定义路由,这些方法对应于HTTP方法; 例如,app.get()处 ...

  9. js 时间戳转特定格式的日期

    var Tools = {}; Tools.formatDate = function (fmt,timestamp) { if(timestamp){ var date = new Date(par ...

  10. Win10系列:UWP界面布局基础12

    画刷 画刷(Brush)用于为图形元素填充颜色.在XAML中,画刷有许多属性,其中较常使用的是Fill属性和Stroke属性,Fill用于填充图形的背景色,而Stroke用于设置图形的线条颜色. 在实 ...