/H5C3_learning

learning H5 and C3. Javascripy in JS_learning.

Primary LanguageHTMLThe UnlicenseUnlicense

H5C3的学习

前端学习

1、HTML、CSS基础、JavaScript语法基础。学完基础后,可以仿照电商网站(例如京东、小米)做首页的布局。

2、JavaScript语法进阶。包括:作用域和闭包、this和对象原型等。相信我,JS语法,永远是面试中最重要的部分。

3、jQuery、Ajax等。jQuery没有过时,它仍然是前端基础的一部分。 

4、ES6语法。这部分属于JS新增的语法,面试必问。其中,关于 promise、async 等内容要尤其关注。 

5、HTML5和CSS3。要熟悉其中的新特性。

6、移动Web开发、Bootstrap等。要注意移动开发中的适配和兼容性问题。

7、前端框架:Vue.js和React。这两个框架至少要会一个。入门时,建议先学Vue.js,上手相对容易。但无论如何,同时掌握 Vue 和 React 才是合格的前端同学。

推荐网站:https://www.w3school.com.cn/

UI设计:Sketch

由于markdown的特性,html不适合在md文件里书写。故截图

目的:精通网页布局,前端必备,为JavaScript做准备!

什么是网页?(切片)

多个网页集合成网站,网页是一页通常是html格式的文件,通过浏览器阅读。

网页的组成:元素组成。称之为HTML文件。

本质是一个标记语言,标记语言是一套标记标签!

image-20220318170403854

网页的形成:前端人员开发代码,浏览器解析渲染,生成web界面

常用的浏览器:火狐,谷歌,safari,opera,IE,Edge

浏览器内核:渲染引擎,读取网页内容。

image-20220318170733079

web标准:W3C组织制定的一系列标准的集合。

1.web标准确保各种浏览器展示一致

web标准:

image-20220318171002663

image-20220318171208147

image-20220318171249090

HTML5基础标签:

多数标签成对出现,单标签少。

image-20220318171651499

双标签:包含关系,并列关系

image-20220318171754677

HTML页面==HTML文档

image-20220318171929724

image-20220318172419684

image-20220318172710102

常用vscode插件

image-20220318173944487

image-20220318180254732

html版本声明

image-20220318181132362

常用标签

html页面语言

image-20220318181353918

定义字符集meta

image-20220318181500655

标签语意:

image-20220318181737094

h1标题标签

image-20220318181905557

p段落标签

image-20220318182203108

br换行标签(单标签)

image-20220318182319895

文本格式化标签

image-20220318182719997

b加粗

i倾斜

s删除线

u下划线

构造盒子标签: div span

image-20220318183344666

图像标签img (单标签)

image-20220318183524526

一般单填一个width,height会等比例刷新

image-20220318183729847

image-20220318184233756

路径问题

image-20220318184652786

image-20220318184913850

超连接a标签

image-20220321142533189

可以进行标签嵌套,让图片也有链接。

image-20220321194710242

image-20220321194731115

HTML注释标签和特殊字符

image-20220323181507159

特殊字符

image-20220323181545611

表格标签

,,
, 用来展示数据。

image-20220323183014370

image-20220323183616453

表格标签属性一般不用,用CSS做

image-20220323183753727

image-20220323184907792

合并单元格

image-20220323185131466

image-20220323190000968

image-20220323185605154

★列表标签,用来布局。ul,li

无序列表ul只能放li

image-20220323190640663

image-20220323191231736

有序列表标签ol只能放li

image-20220323191411630

image-20220323192521444

★表单form

实现用户的搜集和传递

image-20220323193546721

input标签

image-20220323193840161

image-20220323194129734

image-20220323234059570

label标签

image-20220324004851034

select下拉菜单

image-20220324005242014

textarea文本域

image-20220324005600507

H5新增标签

推荐网站:https://www.w3school.com.cn/

1、结构标签
(1)section:独立内容区块,可以用h1~h6组成大纲,表示文档结构,也可以有章节、页眉、页脚或页眉的其他部分;
(2)article:特殊独立区块,表示这篇页眉中的核心内容;
(3)aside:标签内容之外与标签内容相关的辅助信息;
(4)header:某个区块的头部信息/标题;
(5)hgroup:头部信息/标题的补充内容;
(6)footer:底部信息;
(7)nav:导航条部分信息
(8)figure:独立的单元,例如某个有图片与内容的新闻块。
2、表单标签
(1)email:必须输入邮件;
(2)url:必须输入url地址;
(3)number:必须输入数值;
(4)range:必须输入一定范围内的数值;
(5)Date Pickers:日期选择器
(6)search:搜索常规的文本域;
(7)color:颜色;
3、媒体标签
(1)video:视频
(2)audio:音频
(3)embed:嵌入内容(包括各种媒体),Midi、Wav、AU、MP3、Flash、AIFF等。
H5新增属性
 (1)对于js进行添加的属性
<script defer src=".....js" onload="alert('a')"></script> 
<script async src=".....js" onload="alert('b')"></script> 
异步加载先出现b再出现a。

 (2)网页中标签中加入小图标的样式代码
 有序列表ol:新增start(列表起始值),reversed(是否倒置)menu菜单type属性(3个菜单类型)
 内嵌css样式:在标签内部来定义一个样式区块(scoped),只对样式标签内部才有效
 内嵌框架:iframe元素,新增了seamless无边距无边框,srcdoc定义了内嵌框架的内容。

总结新增属性:
 (1)manifest属性:定义页面需要用到的离线应用文件,一般放在<html>标签里
 (2)charset属性:meta属性之一,定义页面的字符集
 (3)sizes属性: `<link>`新增属性,当link的rel="icon"时,用以设置图标大小
 (4)base属性: `<base href="http://localhost/" target="_blank">`表示当在新窗口打开一个页面时,会将href中的内容作为前缀添加到地址前
 (5)defer属性:script标签属性,表示脚本加载完毕后,只有当页面也加载完毕才执行(推迟执行)
 (6)async属性:script标签属性,脚本加载完毕后马上执行(运行过程中浏览器会解析下面的内容),即使页面还没有加载完毕(异步执行)
 (7)media属性: `<a>`元素属性:表示对何种设备进行优化
 (8)hreflang属性: `<a>`的属性,表示超链接指向的网址使用的语言
 (9)ref属性:`<a>`的属性,定义超链接是否是外部链接
 (10)reversed属性:`<ol>`的属性,定义序号是否倒叙
 (11)start属性:`<ol>`的属性,定义序号的起始值
 (12)scoped属性:内嵌CSS样式的属性,定义该样式只局限于拥有该内嵌样式的元素,适用于单页开发


CSS3基础:

image-20220327200901146

作用:

1.美化装饰网页。

2.html结构和CSS样式相分离。

CSS语法规范

image-20220329192023228

image-20220329195232237

代码风格: 展开,小写,加空格

image-20220329195606931

image-20220329195701467

image-20220329195755721

CSS选择器:

1.基础选择器

单个选择器组成。

标签选择器

image-20220330125557091

image-20220330125755166

类选择器(最常用)

image-20220330133335529

image-20220330135855791

image-20220330140816506

image-20220330141745587

id选择器

id属性只能被使用一次,对于每个html来说不能重复使用,应当作为唯一属性

image-20220330141827761

image-20220330143150064

经常作为javascript的首选锚点

通配符选择器(清除内外边距)

image-20220330143857473

设置字体样式:

image-20220330144728668

建议使用常见字体

image-20220330144908025

image-20220330145736316

image-20220330150836205

image-20220330151050350

设置文本样式:

image-20220330155709675

十六进制颜色可以两两缩写

#FF00FF <===> #F0F

image-20220330155645446

图片等其他的文件标签,需要用其父标签去设置位置

image-20220330155918070

image-20220330160525637

一般通过行间距,来调整文本内容垂直方式

image-20220330162024608

CSS四种引入方式:

1.嵌入式(学习用)

image-20220330163400590

2.行内式(非主流,一般用于对文字的修改)

image-20220330163814773

3.链接式(主流用法,单.css保存)

image-20220330164158844

image-20220330164254655

最新方法(不推荐该方法,影响客户端性能):

<style> @import url(style.css) </style>

image-20220420212029479

复用css模板

image-20220420233731151

Chrome调试工具调试样式:

image-20220330165854920

image-20220330170037850

Emmet语法

vscode编辑器(本就内置)

https://code.visualstudio.com/docs/editor/emmet

快捷写法(快速构造框架)

image-20220330172118420

css的复合选择器

image-20220330175312990

后代选择器

image-20220330192816410

子选择器

image-20220330193635122

并集选择器

image-20220330194104276

伪类选择器

image-20220330201508134

image-20220330201725658

image-20220330201742368

image-20220331001955516

image-20220331002051844

css的元素显示模式

什么是元素显示模式?

网页标签非常多,不同的地方会用到不同类型的标签,了解他们的特点可以更好布局我们的网页。

html元素一般分为,块元素和行内元素。

块元素

image-20220331105614884

image-20220331105809401

image-20220331110420941

行内元素

image-20220331110711856

image-20220331125717630

image-20220331130343650

image-20220331132223946

转换成块元素:常用

转换成行内块元素:常用

css的背景

背景图片的导入和渲染方式

image-20220401004657611

背景图片位置

image-20220401004327054

image-20220401005133035

image-20220401010520468

做视差滚动效果

image-20220401011259304

推荐使用复合型的写法

image-20220401011603887

image-20220401012002016

css三大特性

相同的属性值会覆盖,不同的则保留

image-20220401013240582

子类会继承父类的部分属性

image-20220401013454159

行高的继承性

image-20220401014231444

默认选择器权重

image-20220401014358145

继承的权重是0

image-20220401015015779

复合选择器

image-20220401015731803

盒子模型

页面布局三大核心:盒子模型,浮动,定位。

image-20220401133057864

image-20220401133400519

边框属性

image-20220401133801829

image-20220401145315435

边框简写

image-20220401150427062

合理的运用层叠性。

image-20220401151344010

表格调整

一般来说,表格需要细细调整

image-20220401155837244

image-20220401155903521

边框粗细影响盒子大小

image-20220401161808540

内边距,边框和内容的关系

image-20220401162120677

外边距(会影响边框大小)

image-20220401163424377

常用外边距写法:

margin: 0 auto;水平居中

image-20220401180657647

解决外边距塌陷

image-20220401172648021

直接清除所有元素的内外边距

image-20220401172957885

image-20220401172902428

分析布局

image-20220401173346176

1.布局为啥用不同的盒子?

标签有语义,用的多了,就输了。

2.类名or多类名

选取盒子方便,后期维护方便。

3.margin和padding怎么用?

margin不会撑大盒子,padding则会。

4.布局学习主要是由UI设计先做,然后按照比列去做。

圆角边框

image-20220401195733357

image-20220401200810895

image-20220401214717731

image-20220402160030821

image-20220402160208879

网页布局三种方式

image-20220402160739875

标准流

image-20220402160851977

浮动

★改变标签默认排列方式

image-20220402161930378

浮动标签会脱离标准

image-20220402163122767

image-20220402164046532

image-20220402171218275

准备标准流父盒子。然后放浮动盒子

image-20220402171539727

image-20220402181335408

image-20220402181432371

先用标准流的构建大致。

两个注意点:

image-20220402184342488

image-20220402184539110

父盒子:不应该给高度。但是子盒子浮动会导致父盒子失去高度。所以需要清除浮动。

image-20220402191801313

image-20220402191856216

清除浮动,方法一

image-20220402192659867

清除浮动,方法二

image-20220402193018398

清除浮动,方法三

image-20220402193631045

.clearfix:after {
            content: "";
            display: block;
            height: 0px;
            clear: both;
            visibility: hidden;
        }

        .clearfix {
            /* IE6/7专有 */
            *zoom: 1;
        }

image-20220402195521898

.clearfix:after,
        .clearfix::before {
            /* 伪元素 */
            content: "";
            display: table;
        }

        .clearfix:after {
            clear: both;
        }

        .clearfix {
            /* IE6/7专有 */
            *zoom: 1;
        }

image-20220402201443097

常用工具和布局思路

1.学习下PS

2.图层切图

3.切片切图

4.PS插件cutterman(推荐)

image-20220402205010063

image-20220407140202271

静态页面笔记:

1.实际开发中,导航栏我们不会用a标签,而是用列表标签包含a标签的做法,链接

  • image-20220408205317674

    定位

    为什么要用定位

    浮动可以让多个块级盒子一行没有缝隙排列现实,经常用于横向排列行字。

    定位则是可以让盒子自由的在某个盒子内移动位置或者固定屏幕中某个位置,并且压住某个盒子.

    image-20220420153757027

    image-20220420153816045

    定位:定位模式+边偏移

    定位的四种分类

    image-20220420154150224

    image-20220420154229147

    四种定位的特点

    静态定位:

    image-20220420154334884

    相对定位:

    image-20220420154608781

    绝对定位:

    相对定位一般是用来给绝对定位当参考的。

    image-20220420161134479

    常用子绝父相布局

    image-20220420162732120

    常用来做轮播图

    固定定位

    常用来做贴边导航

    image-20220420164848517

    image-20220420182658903

    常用的一种版心贴靠固定盒子的方法。

    image-20220420183949246

    粘性定位

    image-20220420190949213

    image-20220420194652867

    定位叠放顺序

    image-20220420201755827

    定位拓展

    施加了定位的对象,则默认浮动

    image-20220420203511436

    image-20220420203458984

    image-20220420204030806

    使用定位时要注意

    先left后right,先top后bottom

    image-20220423195930145

    定位小总结

    标准流:盒子竖直排列。

    浮动:让盒子横向排列。(做展示)

    定位:让盒子可以放在任意位置。(JS可以做下拉菜单)

    元素的显示与隐藏

    可关闭的插图广告。

    image-20220423211039919

    ★display显示隐藏

    display:none; 隐藏对象,清除占位。

    display:block; 转换块级元素,并且显示元素。

    应用广泛,搭配JS可以做很多特效。

    visibility显示隐藏

    visibility: visible; 元素可视

    visibility: hidden; 元素隐藏,但不清除占位。

    overflow溢出显示隐藏

    overflow: visible; 显示溢出

    overflow: hidden; 隐藏溢出

    overflow: scroll; 让内容滚动

    overflow: auto; 自动选择滚不滚动

    CSS高级技巧

    精灵图

    web页面以左上角为坐标原点

    image-20220423221214784

    CSS精灵技术:将网页中的一些小背景图,整合到一张大图中,客户端根据需要进行分割显示。(减少服务器压力,只要定位精确,很方便)

    image-20220423221528071

    image-20220423223225045

    如何用PS切片

    image-20220423225859823

    字体图标

    image-20220423230502222

    image-20220423230550110

    下载方式:

    image-20220423232117158

    使用方式:

    image-20220423231925004

    字体格式

    image-20220423232251897

    该方式不推荐

    image-20220423235347006

    根据每次下载的文件夹的不同,可以不断添加自己想要的图标。

    CSS三角

    利用边框去做三角形,本质上也是一个盒子.

    image-20220424130141030

    常见CSS用户界面样式

    image-20220424131214051

    image-20220424135714011

    缺陷

    image-20220424144008563

    文字溢出,显示省略号

    image-20220424152853222

    image-20220424153907324

    image-20220424155959296

    具体布局,请看day6的代码。

    初始化布局

    一般用来初次导入css,避免出现兼容性问题!

    image-20220424181623266

    H5C3进阶:

    混合app需要H5C3的新特性和新知识,建议掌握完全。

    H5新特性

    列举一些常用的新标签

    image-20220424203552351

    image-20220424222617444

    新增多媒体标签:

    image-20220425113412192

    image-20220425113927629

    image-20220425201934201

    image-20220425202053734

    新增表单验证

    image-20220425202525383

    image-20220425213859478

    C3新特性

    image-20220426002237053

    image-20220426144316894

    image-20220426144305483

    image-20220426145552154

    n从0开始到最后一个子类序数。小学数学

    image-20220426152132607

    image-20220426153904225

    image-20220426154246223

    image-20220426163741687

    image-20220426164650055

    image-20220426165334751

    图片模糊

    image-20220426171542002

    宽度计算

    image-20220426171520772

    过度动画

    运动曲线决定效果。

    image-20220426180320155

    实战项目:

    品优购

    模块化,代码复用

    image-20220427150202539

    image-20220427150414928

    TDK搜索引擎优化(一般是SEO人员设置)

    image-20220427151228040

    image-20220427160232252

    选项卡(需要js)

    image-20220430160620118