一、有序列表、无序列表、自定义列表如何使用?写个简单的例子。三者在语义上有什么区别?在哪些情况下使用哪种(重要)? 如何嵌套?
- 有序列表:是使用编号(数字或字母)来记录项目顺序,适用于有前后顺序,需要排列和有次序的内容列表。
- 无序列表:是使用符号(圆点)来记录无需项目,适用于并列、地位相同的内容列表,也就是说没有先后关系。而在大部分网页中都是使用无序列表。
- 自定义列表:适用于含有标题,需要解释的项目内容。
二、如何去除列表前面的点或者数字?
- list-style:none;
三、class 和 id 有什么区别?什么时候用 class 什么时候用 id?
- 区别:一个元素可以有多个class,而一个元素只能有一个id;id的优先级高于class;class在结构内部使用,通常用于样式定义,id在结构外使用,通常用于页面布局;
- 利用class选择器设置样式可以重复利用,所以通常在样式的定义的时候会去使用class;id一般在使用js的时候应用,或是元素只会出现一次;
四、块级元素、行内元素是什么?有什么区别?分别对应哪些常用标签?
- 块级元素:默认占一行高度,表现为开始另起一行,一行内添加一个块级元素后无法一般无法添加其他元素(float浮动后除外),在文档流中从上自下排列。
行内元素:占内容自身的高度,不会独占一行,和相邻的内联元素在同一行,在文档流中从左至右排列。 - 区别:
块级元素总是独占一行,表现为另起一行开始,而且其后的元素也必须另起一行显示; 宽度(width)、高度(height)、内边距(padding)和外边距(margin)都可控制;
行内元素和相邻的内联元素在同一行; 宽度(width)、高度(height)、内边距的top/bottom(padding-top/padding-bottom)和外边距的top/bottom(margin-top/margin-bottom)都不可改变,就是里面文字或图片的大小; - 常用标签:
块级元素主要有:
address , blockquote , center , dir , div , dl , fieldset , form , h1 , h2 , h3 , h4 , h5 , h6 , hr , isindex , menu , noframes , noscript , ol , p , pre , table , ul , li
内联元素主要有:
a , abbr , acronym , b , bdo , big , br , cite , code , dfn , em , font , i , img , input , kbd , label , q , s , samp , select , small , span , strike , strong , sub , sup ,
五、display: block、display: inline、display: inline-block分别有什么作用?
display: block——显示为块级元素,并继承了块级元素的特性
display: inline——显示为行内元素,并继承了内联元素的特性
display: inline-block——显示为内联块元素,表现为同行显示并可修改宽高内外边距等属性。
六、
页面基本布局主要是说明页面的基本布局结构主要由header、nav 、sidebar、content、footer组成的,并且都包裹在
.wrap
中,可使各区块居中显示;
七、如何理解 HTML CSS 语义化? 在平时写代码的过程中要注意哪些细节
- HTML语义化:语义化的含义就是用正确的标签做正确的事情,html语义化就是让页面的内容结构化,便于对浏览器、搜索引擎解析;在没有样式CCS情况下也以一种文档格式显示,并且是容易阅读的。搜索引擎的爬虫依赖于标记来确定上下文和各个关键字的权重,利于 SEO。使阅读源代码的人对网站更容易将网站分块,便于阅读维护理解。
- 注意细节:
(1)尽可能少的使用无语义的标签div和span;
(2)在语义不明显时,既可以使用div或者p时,尽量用p, 因为p在默认情况下有上下间距,对兼容特殊终端有利;
(3)不要使用纯样式标签,如:b、font、u等,改用css设置。
(4)需要强调的文本,可以包含在strong或者em标签中(浏览器预设样式,能用CSS指定就不用他们),strong默认样式是加粗(不要用b),em是斜体(不用i);
(5)使用表格时,标题要用caption,表头用thead,主体部分用tbody包围,尾部用tfoot包围。表头和一般单元格要区分开,表头用th,单元格用td;
(6)表单域要用fieldset标签包起来,并用legend标签说明表单的用途;
(7)每个input标签对应的说明文本都需要使用label标签,并且通过为input设置id属性,在lable标签中设置for=someld来让说明文本和相对应的input关联起来。
八、form表单有什么作用?有哪些常用的input 标签,分别有什么作用?
form表单的作用:用于把用户输入的数据提交到后台。
name:表单提交时的名称
active:提交到的地址,比如一个PHP页面
method:提交的方式,有get和post两种
- 常用的input:
<input type="text">
文本输入框
<input type="button">
自定义按钮
<input type="submit">
提交按钮
<input type="radio">
单选框
<input type="checkbox">
复选框
<input type="password">
密码输入框
<select><option></option><option></option></select>
列表选项
<textarea></textarea>
文本域,输入多行文本
九、post 和 get 方式的区别?
- get提交的url数据可见,post不可见;get一般用来提交少量数据来获取大量数据,多用于查询,post用于提交大量数据,例如写文章,写评论;get最多用于提交1k的数据,由于所有数据都会拼接成url所以浏览器会有限制,post没有限制;get安全性不好,所以不能用来提交用户名密码;
十、在input里,name 有什么作用?
- 当submit打包表单数据提交给后台时,后台是根据input的name来获取数据的,所以input必须要有name;当我们点击提交按钮的时候,我们及将数据上传到对应的文件里,后台假设使用php,那么php对应的文件根据对应的input标签里面的name可以获取到对应的value。http://www.jianshu.com/p/ccb02aea218a
十一、<button>提交</button>、<a class=“btn” href="#">提交</a>、<input type=“submit” value=“提交”> 三者有什么区别?
-
<button>提交</button>
只是一个自定义按钮,无交互 -
<a class=“btn” href="#">提交</a>
仿按钮 -
<input type=“submit” value=“提交”>
提交按钮,用于后台数据交互
十二、radio 如何 分组?
- 将name值设为相同值
十三、placeholder 属性有什么作用?
- 给input添加一个灰色的提示值
十四、type=hidden隐藏域有什么作用? 举例说明
-
type="hidden": 隐藏域,用户看不到,用于暂存数据。或者安全性校验
隐藏域可以暂存一些信息,提高安全性,隐藏域在页面中用户是不可见的, 在表单中插入隐藏域是为了收集信息,用户点击提交按钮的时候,隐藏域的信息就随着表单一起发送到了后台,就可以确定用户身份了
后台验证身份
网友评论