写给IOS开发工程师的网页前端入门笔记

前言:作为IOS开发工程师,终会接触到网页前端开发,甚至可能会有 用HTML5开发IOS的app客户端的需求。比如现在上架的app就有比如理财类型的app有的就用HTML开发的,从理财类型的app需求上思考,用 HTML5确实是个不错的选择,利用了跨平台的同时,也考虑到了理财类型的app仅仅需要处理的是数据的业务逻辑,不存在较多的本地存储数据,而且涉及到 的财务信息从安全性考虑数据基本都会存储在服务器端,是不可能用于存储在本地的,再加上HTML5对各种手机屏幕的尺寸适配性非常灵活,所以这一类app 用HTML5开发是非常正确的选择。不过本文涉及的内容是针对IOS工程师所需的知识内容,所以并没有涉及网页前端所有的开发细节。

 

HTML5简介

HTML5 - 简单
8年发展 - 标准
UI界面跨平台 - 写一份HTML5代码,这个界面就可以运行到任何手机平台
运行平台 - 浏览器
移动先行 - 以前的HTML(5以上的版本)都是运行在非手持设备运行的
原生 - 比如手机自带的手机相册\打电话\拍照
    >手机app的常见的开发模式 :原生+HTML5

网页的基本组成

一个有具体功能的完整的网页,一般由3部分组成
    HTML
        决定网页的具体内容和结构
    CSS
        代表网页的样式(美化网页最重要的一块内容)
    JavaScript
        网页的交互效果,比如对用户鼠标事件作出响应
<HTML和CSS需要了解就好,因为需要掌握大量东西才好做CSS美工方面的东西>

HTML编写

什么是HTML?
    HyperText Markup Language 超文本标记语言
    其实就是文本,由浏览器负责将它解析成具体的网页内容
前端开发工具:
    >sublime text : 拓展性非常强(安装各种插件)\颜色经典
    >Dreamwaver : 美工(Adobe公司开发)
    >WebStorm : 自带了各种插件 比如Nodejs grunt less
    >Eclipse : 主要开发Java程序
head一般放CSS和JS的,body一般放内容。
title一般放置描述性内容。

常见的HTML的标签: 百度就能了解。

CSS编写

什么是CSS?CSS的全称是Cascading Style Sheets,层叠样式表
它用来控制HTML标签的样式,在美化网页中起到非常重要的作用

CSS的编写格式是键值对形式的,比如:

123
color : red;background-color : bluefont-size : 20px;         冒号左边的是属性名,冒号右边的是属性值

CSS的三种书写形式:

  • 1、行内样式:(内联样式),就是直接在标签内部添加样式,直接作用到当前样式
12
<p style="color: red; font-size:20px; background: #00f"></p>弊端:只能作用于当前标签,对于多个重复的多个的,大量的重复的就不好了。
  • 2、页内样式:
123456789101112131415161718
<head>	<style>		p{			color: red;			font: 40px;			background: orange;		}这个就是指定p标签的样式CSS	</style></head><body>	<p>loaojhaljeoijfaojfaojf;al</p>	<p>loaojhaljeoijfaojfaojf;al</p>	<p>loaojhaljeoijfaojfaojf;al</p>	这样这里所有的p标签的样式都会被上面的CSS样式所设定	<p style="color: yellow">loaojhaljeoijfaojfaojf;al</p>	如果标签自己又设置了和样式标签有冲突的属性,代码会自动就近原则。 </body>弊端:只能用在当前网页
  • 3、外部样式:在单独的CSS文件中书写,然后在网页中用link标签引用

为了能够作用到项目里的所有HTML文件,就有必要新建一个xxx.css文件:

12345
div{	color:red;	font-size: 50px;	border: 1px }

然后在需要设置CSS样式的网页上添加连接这个自定义CSS文件

12345678
<head>	<link rel="stylesheet" href="xxx.css" > 	rel是relation关系的意思	href就是Hypertext Reference(超文本引用)的缩写</head><body>	<div>second</div></body>					三种方式没有优先级,如果要考虑优先,原则就是就近原则。

CSS选择器

CSS有两大核心:选择器、属性(学好CSS,只要学好这两个就好了)

代码格式就是:
12345
选择器{	属性1;	属性2;	。。。。。。}
选择器使用实例1
选择器的作用:选择对应的标签,为之添加样式
div{
    color:red;
    font-size: 20px;
    border:5px;
}
html中的某个标签:
...
<body>
    <div>second</div>
</body>
...
这个div标签选择器,会根据标签名找到对应标签<div>,
然后把选择器里的属性设置到对应标签的内容上。
这里就是把color:red;font-size:20px;border:5px;设置在second这个内容上
选择器使用实例2

标签选择器:根据标签名找到标签

12
<div>div1</div><div>div2</div>

下面是选择器:

12345
div{	color:red;	font-size: 20px;	border:5px;}

因为两个标签的标签名都是div,所以选择器里的属性都会作用于div1和div2

下面讲讲不同类型的类选择器:

类选择器:

12345
<p class ="high">第一段文件</p><p>第二段文字</p>

<div class ="high">div1</div><div>div2</div>
然后在CSS文件中:
123
.high{	color: red;}
这个标签是作用于class类标签属性是high的标签,所以会作用于"第一段文字"和"div"
总结:class标签就是可以把不同类的标签可以归为一个类class
注意
    类选择器开头要有"."符号哦
    类选择器的名字可以是标签中class属性字符串的一部分
        比如:.he类选择器名可以访问class = "woe he llo"的标签(注意要空格隔开的,不隔开(比如woehello)无用)
    "."是用来找class属性的,而"#"是用来找id属性的。

id选择器:

1234567891011121314151617
<!DOCTYPE html><html><head lang = "en">	<meta charset="UTF-8">	<title></title>	<style>		#rose {   			font-size: 50px;		}	</style></head><body>	<div class="tom jerry" id="jack">11111</div>	<p class="tom">2222</p>	<a class="jerry" id="rose">222</a></body></html>
如果id="rose"的标签有两个,IDE会报错,浏览器运行无效。
和类标签选择器一样,Class通过.符号去选择,id选择器通过#符号去选择
#rose选择器表示查找并将这里面的属性设置到标签中id是rose的标签

群组选择器

  • 普通形式,神马标签都写上:
123
div , p , a {	font-size:50px;} 	其实质意义上div,p,a三者是并列的。

再举一个并列选择器(或者):

123
div , .high{	color: red; };

作用:只要标签中有div或者有class=”high”或者是div和class=”high都有的都能设置

另外,如果要设置所有标签的设置,那么选择器名可以是符号 *

123
* {	font-size: 50px;}

复合(并且):

123
div.high{	color: red;}

还有就是需要同时符合三个条件,而且顺序不能乱:

123
div.high#jack{	color: blue;}

意思就是,必须既是div,而且是class属性有high,最后还要id为jack都满足的标签

后代选择器(之间空格):

123
div .tom {	color: red;}

就是找到div里面class=”tom”的所有子标签

如果是:

12
div p div span p{}

就要找到div包含的p,这个p包含的div,这个div包含的span,这个span包含的p

然后根据后代又分为两种: 1、直接后代选择器,2、相邻兄弟选择器

12
div > p {}

这里就是针对直接后代的,就是div包含的直接p标签,不是间接包含的标签

12
div + p {}

相邻兄弟选择器,找到相邻的选择器

属性选择器:

1234
div[name]{}div[name][id]{}

CSS的优先级(从1~4优先级别越来越低):

12345678
带有 !important 的属性在style属性中的样式先比较选择器的优先级,优先级高的会覆盖优先级低的。	针对性越强(范围越小)的选择器,优先级越高	针对性越弱(范围越大)的选择器,优先级越低	例子:<div class="hello" id="jack">hewelf</div>	这里明显,id属性能够限定的标签最小,甚至对应的是一个标签。如果优先级都相同,再比较选择器的先后顺序,后面的会覆盖前面的。
还有一种别人总结的经验:算权值
标签 1 类 10 id 100 然后求和计算css的选择器的权值
CSS的注释是这样的 /* 内容 */
但是在CSS中//这样的注释是无用的。
12
HTML注释:	<!-- 内容 -->
1234
CSS标签用的冒号叫"伪类"div:hover {	color: blue;}hover表示鼠标悬浮在div标签上面的时候,会设置相关的属性,这里会让div标签内容变成蓝色

CSS选择器–伪类(了解):

HTML的输入框初识

...
<input placeholder="请输入用户名">这个就是在输入框内添加浅色的提示
...

Term和Alfred2的使用


iTerm和Alfred2的安装和使用笔记网址:http://www.cnblogs.com/goodboy-heyang/p/4909296.html

标签类型

根据显示的类型,主要分为3大类

块级标签

绝对独占一行的标签
随时设置自己的宽度和高度
(比如div、p、h1、h2、ul、li)

行内标签(内联标签)

多个行内标签能同时显示在一行
宽度和高度取决于内容的尺寸(比如span、a、label)

行内-块级标签(内联-块级标签)

12345678910111213141516171819202122232425262728
多个行内-块级标签可以显示在同一行能随时设置宽度和高度(比如input、button)

display:显示比如:	display:inline-block  行内-区块	display:inline 行区	display:block  块使用示例,这里将默认是块级的div设置为行内:<!DOCTYPE html><html><head lang="en">   	<meta charset="UTF-8">   	<title></title>   	<style>      	div{         	display: inline;       	}   	</style></head><body><div >hello</div><div >world</div></body></html>这里实例原本div标签的hello和world是分别显示在两行的,各自独占一行,然后因为div选择器设置display: inline;意思就是将div标签设置为行内标签,那么会发现效果hello和world就都显示在一行里了。
12
display:inline-block可以将内容设置为既是行内标签又是块级标签,这样你可以仅仅把div当做简单的容器就是了。
12
display:none就会让内容不显示,这个display相当于IOS里的show方法visiblity:hidden 仅仅是看不到

百度首页

源码下载百度云备份链接: 百度首页实例 密码: yzyv

网页开发须知:
    工程项目文件目录
    css文件夹
        index.css
    script文件夹
    index.html
美工开发一般步骤:
    先在html.index内定好结构,类似IOS开发中的规划好UI布局,每一块放好一块内容。
    然后在index.css文件中根据html.index分好的块分别设置样式。
    然后就是慢慢调整,很耗费时间的。

bootstrap

12345
这是网页前端最受欢迎的第三方框架另外,如果要学习可以到网站 v3.bootcss.com在下载的bootstrap框架中css/下的我们能用到的就是bootstrap.css和bootstrap.min.css,其他的可以删除。bootstrap.css和bootstrap.min.css的区别就是min将内部的空格都去了,这样文件小了,就可以节省流量。所以bootstrap.css叫开发版本,然后bootstrap.min.css叫上线版本

官方开发文档展示了很多模板代码使用样式

说白了,这个框架就是帮你封装了一堆漂亮的样式,然后你只要会用即可。
有一些图标被设计成字体,然后存储在fonts文件夹下的字体文件内,所以需要把整个fonts文件夹拷贝进工程根目录。
在使用图片文字的时候,如果要调整大小,要注意,因为是文字,所以直接用font-size属性设置值就对了。

JS核心语法

浏览器就是JS的运行平台,就好比IOS就是OC的运行平台。

JS的常见用途

HTML DOM操作(节点操作,比如添加、修改、删除节点)
给HTML网页增加动态功能,比如动画
事件处理,比如监听鼠标点击、鼠标滚动、键盘输入

JS的书写方式

1234567
1、JS代码写在双引号里面。	<button onclice="alert(10);alert(99);">拍照</button>	这段JS代码可以写在html的<body>标签里,效果2、脚本中执行	<scipt>		console.log(100);	</scipt>

另外,JS所有的变量都是用var,实例:var 变量名 = 变量值

数据类型

12345
number 所有数字,比如小数/整数object 所有类型 比如{}.[]string 字符串类型,用双引号""或者单引号'',建议JS都用单引号	原因示例:<body onclick ="alert('hello')"></body>如果hello用双引号,肯定会冲突的。function 函数类型

定义函数

12345678910
function 函数名(形参){	//函数体}	函数定义注意,如果两个或者两个以上的函数函数名一样,后面的会直接覆盖前面的,	没有重载的意义,就是直接的覆盖。最后使得只有最后一个函数有用或者会被调用。	function sum(num1,num2,num3,num4){		return num1 = num2 + num3 + num4;	}	//会返回NaN = Not a Number	console.log(sum(10,20));

函数实例:

123456789101112131415161718192021222324252627282930313233343536373839
1.简单的示例:var dog = {age : 30;run : function(){ 		//this 相当于 OC里的self 		console.log(this.age + '岁的狗跑起来。'); 	} } 2.关于多个参数的示例: function sum(){ 	console.log(arguments); } //JS会把多个参数存储在一个默认的数组arguments里面 sum(2+2+12);//然后会打印出[2,2,12] 3.求和多个参数 function sum(){ 	for (var i = 0,){ 	} } //JS会把多个参数存储在一个默认的数组arguments里面 sum(2+2+12);//然后会打印出[2,2,12] 3.多个参数返回求和(可以把字符串数值和数值类型数值都能相加)   <script>       function sum(){           var num = 0;           for(var i = 0;i<arguments.length;i++){               var temp = arguments[i];               if (typeof temp == 'number'){                   num += temp;               }else if(typeof temp == 'string' &&  !isNaN(temp *= 1)){                   num += temp;               }           }           console.log(num);       }       sum('1',2,3,4,'hello');   </script>   4.看看函数的类型   console.log(sum)//不要用sum()这个是调用函数了

对象

123456789101112131415161718192021222324252627282930313233
最简单的对象var dog = {};然后添加属性:var dog = {	age : 20;	name: 'rose';};console.log(dog.name);然后要访问这个dog的属性的两种方法:console.log(dog.age);//点访问属性console.log(dog['age']);//字典访问属性这里提一个易错点:dog[age]这样会得到age的变量值,然后再访问字典字,所以会出bug的。下面讲讲对象的方法:function temp(){	console.log('跑起来');}var dog = {	age : 20;	run : temp;};当然把函数写成匿名函数,把函数直接封装在对象里面var dog = {	age : 20;	run : function(){		console.log(this.age + '岁的狗跑起来')	}}//如果this.age没有this的话,就会报错,JS明确必须要用thisdog.age = 40;dog.run();//函数也可以重新赋值或者叫覆盖dog.run = function(){	console.log(this.age + '岁汪汪叫');}

数组、字典都是对象类型

数组实例:

var array = [12,'dog',24,'jack',{
    name : 'wangcai'
},[],function(){
    console.log(10);
}];
array[array.length-1]();
时间: 2024-08-18 10:34:39

写给IOS开发工程师的网页前端入门笔记的相关文章

奔向三张,不破不立:一个iOS开发工程师的职业规划思考

  大前天下午快下班那会儿,跟念茜聊了一下各自的工作现状,发现她现在碰到的一些职业规划上的困惑,跟我在一年多前的情况非常相似.而我经过一年多来的不断思考和调整,已经基本明确了自己的职业规划,发展的方向变得越来越清晰,配合我个人较强的执行力,困惑越来越少,事情也正在朝着越来越好的方向发展.念茜和我是iOS开发行业中的普通年轻从业人员,因此我们的困惑具有一定的代表性.今天,我就跟大家说说这两年来我的职业规划心路历程,供大家参考.   看过书上自序部分的朋友都知道,我从读硕士开始,就已经进入iOS领域

TDD的iOS开发初步以及Kiwi使用入门

测试驱动开发(Test Driven Development,以下简称TDD)是保证代码质量的不二法则,也是先进程序开发的共识.Apple一直致力于在iOS开发中集成更加方便和可用的测试,在Xcode 5中,新的IDE和SDK引入了XCTest来替代原来的SenTestingKit,并且取消了新建工程时的"包括单元测试"的可选项(同样待遇的还有使用ARC的可选项).新工程将自动包含测试的target,并且相关框架也搭建完毕,可以说测试终于摆脱了iOS开发中"二等公民"

2015年iOS开发工程师前景分析

"互联网+"概念的提出催生了大量互联网企业,越来越多的传统行业需要与互联网更深地渗透与融合.而在这股互联网化的浪潮中,行业却发现找不到优秀的互联网人才. 互联网企业数量持续增长,用人需求居高不下 今年两会,政府工作报告中提出了"互联网+"的计划,并出台了一系列政策,推动互联网,尤其是移动互联网在商务.工业.金融等行业的应用和服务深化发展,并着重扶持中小企业及微型企业的发展,中国的互联网企业数量持续大幅度增长.而在传统行业向互联网转型.互联网中小企业起步和发展这两个领

前端开发工程师和美工掌握的知识的区别

文章描述:前端开发所需掌握的知识. 摘要:很多公司甚至是多数以互联网网站为主要业务的公司都会把"美工"的概念搞混淆,通常这些公司都会把网页设计+网页制作的人员统称为"美工".而一家成熟的互联网公司则会把网站方面的人才规划的比较详细,如UED团队(用户体验设计,英文User Experience Design的缩写),其中详细划分成了"交互设计"."视觉设计"."前端开发"."用户研究".

网页前端开发工具推荐

  当启动一个新的项目,使用 CSS 框架或样板,可以帮助您节省大量的时间.在这篇文章中,我编译整理了我最喜欢的 CSS样板,框架和库,帮助你在建立网站或应用程序时更加高效. Bootstrap 开发工具推荐-网页前端开发工具"> 如果你想给你的新项目的专业的外观和感觉,Boostrap 可能是你需要的工具.它拥有一个非常干净的排版,表格元素,以及设计一个现代化的网站你需要的所有东西.更多信息: twitter.github.io Foundation Foundation 来自 Zurb

iOS开发之山寨版新浪微博小结

在之前的博客IOS开发之新浪围脖中获取微博的内容是使用我自己的access_token来请求的数据,那么如何让其他用户也能登陆并获取自己的微博内容呢?接下来就是OAuth和SSO出场的时候啦.OAuth的全称为Open Authorization 开发授权,SSO--单点登陆(Single Sign On).至于其原理是什么,更具体的介绍网上的资料是一抓一大把,在这就不做过多的原理性的概述.当然啦,OAuth和SSO在Web和其他手机终端上应用还是蛮多的,所有这方面的资料也是多的很. 简单的说就

网页前端开发,对于图片慢加载简介

技术背景       现在的网页系统,对于一些对图片资源比较多,并且一次性无法浏览完整个网页的情况下,图片慢加载可以提高客户端的体验,如IT大头:淘宝,网易,新浪等等...   技术原理   技术说穿了其实也就那么回事,懂了就简单了,呵呵~      1.   预设图片的属性,"src"指向一个小图,"_src"指向真是的图片地址:      2.   获取浏览器滚动事件:      3.   计算当前浏览器下拉的位置,通过高度判断是否需要加载图片:      4.

网页前端开发优化的参考List

网页制作Webjx文章简介:一些前端开发优化的经验总结. 发现的一篇关于前端优化的文章,总结的很全面,要做到面面俱到很难,往往是想优化而没有时间去优化,就像我们公司,一个项目连着一个项目~新员工的培训都省了,还想优化前端啊,不过我真的想有机会和老大好好的整合下公司网站的前端代码~不过要把前端优化的工作放在平时的写代码中去,就不需要刻意的后期优化了.在项目开发中,后台需要搭建好框架,前端更是需要搭建好框架,并且在页面实现中得到实现,只有这样才能事半功倍. 前段时间简单的研究了下前端优化相关的知识,

Web前端开发工程师基本要求

      一位好的Web前端开发工程师在知识体系上既要有广度,又要有深度,所以很多大公司即使出高薪也很难招聘到理想的前端开发工程师.现在说的重点不在于讲解技术,而是更侧重于对技巧的讲解.技术非黑即白,只有对和错,而技巧则见仁见智.以前会Photoshop和Dreamweaver就可以制作网页,现在只掌握这些已经远远不够了.无论是开发难度上,还是开发方式上,现在的网页制作都更接近传统的网站后台开发,所以现在不再叫网页制作,而是叫Web前端开发.Web前端开发在产品开发环节中的作用变得越来越重要,