(1)*{padding:0;margin:0} 去除所有元素默认的padding和margin,这句话是经常会在网页制作中应用到的
(2)ul{list-style-type:none;} 去除列表项默认符号
(3)$("#list :hidden").css("display","block"); jQuery中的语句,显示类选择器list下面的隐藏元素
(4)#list *{display:none;} 设置类选择器list下面的元素隐藏
(5)三种动态网页技术:PHP,JSP,ASP.NET
(6)前端技术:HTML5,CSS,JavaScript,Ajax(Asynchronous Javascript And XML(异步JavaScript和XML)),SEO(Search Engine Optimization(搜索引擎优化))
(10)JavaScript在HTML中的引用共有4种:head标签内引入,body标签内引入,元素事件中引入,引入外部JS文件
(11)JavaScript的设计原则主要来自于Self和Scheme。JavaScript的作用,通俗的来讲就是做特效使用的
(12)学习截止到这里: 2.2 JavaSsript数据结构 3.5 内容伪类选择器
(13)所有JavaScript变量都是由var声明。一个好的编程习惯是,在代码开始出,统一对需要的变量进行声明
(14)JavaScript中的基本数据类型:Number(所有数字都是有浮点数表示的),String,Boolean。特殊数据类型:null,undefined,转义字符
(15)JavaScript中,程序中的字符串型数据是包含在单引号或双引号中的,由单引号定界的字符串中可以含有双引号,由双引号定界的字符串中也可以含有单引号。单引号出现双引号”或“双引号出现单引号”时,不需要进行转义。但是,“单引号内出现单引号”或“双引号内出现双引号”则必须进行转义
(16)JavaScript中的布尔型的值为true,一个对象的值为true,"0,空字符串,null,undefined"值为false
(17)null不占有内存空间,表示一个变量被赋予了空值。undefined不占有内存空间,表示变量还未被赋值,undefined比null更低级一些。空字符串和0是占有内存空间的。
(18)NaN表示的是一个非数值型数据
(20)typeof(null)的值是object。
(21)typeof()运算符用于返回操作数当前所容纳的数据类型,常用于判断一个变量是否已经被赋值
(21)JavaJavaScript里面的常量,变量等是严格区分大小写的
(22)var d=new Data();var time=d.getHours();//获得小时数
(23)var d=new Data();var time=d.getDay();//获得星期几
(24)var str="how are you";var length=str.length;var cha=str.charAt(i);//注意,i是从0开始数的
(25)定义函数必须使用function关键字
(26)函数执行=定义函数+调用函数
(27)定义函数的参数叫形式参数,调用函数时的参数叫实参
(28)学习截止到这里: 4.4 几种特殊的函数 3.5 内容伪类选择器
(29)伪类选择器中,:header表示选择h1~h6的标题元素。伪类选择器都是以英文冒号开头的
(30)odd代表奇数,even代表偶数
(31)$("p:contains(jQuery)").css("background-color", "red");会让包含jQuery的这一行颜色都有所改变
(33)jQuery里面的选择器分为四种:基本选择器,层次选择器,伪类选择器,表单选择器
(34)获取元素属性:$().attr(
"属性名"
)
设置元素属性:
$().attr(
"属性名"
,
"属性值"
)
删除元素属性:$().removeAttr(
"属性名"
)
(35)超链接里面的title设置的是,当鼠标移动到这个链接上面的时候,给出的提示
(28)学习截止到这里: 4.4 几种特殊的函数 4.2 内容操作 第二章 线性表(3)
(29)<input text="text" id="num1"> var x=document.getElementByID("num1").value x可以直接用来参与运算了
(30)递归中尽量使用 return num*arguments.callee(num-1);这样在调用的时候不会出错。arguments.callee是一个指向正在执行的函数的指针。
(31)eval()的功能非常强大,但是不经常使用它。eval()函数可以把一个字符串当做一个JavaScript表达式一样去执行计算。
(32)isFinite()函数用来确定某一个数是否是一个有限数值
(33)isNaN()函数来判断一个值是否是NaN值(非数值型)
(34)parseInt()函数和parseFloat()函数
(35)JavaScript中的字符串,可以用单引号或者双引号引起来,这个都是无所谓的
(36)null和undefined没有toString()方法。两种不同的用法:String(变量名称),变量名称.toString(2)转化成二进制
(37)$(
"#p2"
).html(
"<strong>jQuery入门教程</strong>"
);用来改变页面元素的内容
(38)jQuery中,html()是认页面元素标签的,而text()是不认页面元素标签的
(40)获得宽度的时候,可以通过这两种方法实现:$().width();结果为“100”。$().css("width")结果为“100px”
(41)设置宽度的时候,可以通过这种方法来实现:$().width(100),$().css("width","100px"),不能混淆,要不
然容易出错
(43)如果我们对父元素设置position:relative,我们就可以使用position:absolute来设置子元素相对于父元素的
定位距离,这就是我们常说的“外相对,内绝对”
(44)学习截止到这里: 6.1字符串对象简介 6.1 DOM操作简介 第二章 线性表(3)
(45)getDate()返回一个月中的第几天,1-31之间的一个整数
(46)getFullYear(),getMonth(),0-11之间的一个整数
(47)getDay()返回一个星期的第几天,星期日的值是0
(48)传统密码:安全是基于对算法进行保密,对参数进行保密。
(49)公钥密码使得发送端和接收端无秘钥成为可能
(50)秘钥就是加密算法:移位密码,取任意一个字母按照一定的对应方式去修改。置换密码,置换字母位置
转子机。对称密码算法DES:秘钥长度短,不是那么安全了,内部的设计是保密的
(51)加密操作:代换,置换,多重加密
(53)对称加密:发送方和接收方共享相同的秘钥。怎样破解?分析加密算法,或者强力攻击,就是根据已知信息,
遍历出所有可能的密码
(54)公开秘钥密码学相关的两个问题:秘钥分配,数字签名
(55)公钥加密算法:是密码学的分水岭,使得密码学成为一门科学。要求有一个公钥和一个私钥,双方很难相互推导出来
。发送方和接收方使用不同的秘钥。公钥加密算法比对称加密算法要慢很多倍。公钥加密又叫非对称加密算法。
公钥加密算法是目前使用最广泛的加密算法。加密消息的秘钥是不能来解密消息的。甲用乙的共有秘钥对报文进行加密,
只有乙的私有秘钥才能够解密消息,这谁
都不能知道。报文一定是用乙的私有秘钥加密(签名)的。先签名,再加密。
当报文用用乙的私有秘钥加密,再用共有秘钥加密后。如果甲收到的报文是无误的,才能用已的共有秘钥解开报文。同时,
既然能解开,说明报文就是乙发送的。
(17)RSA算法,奠定了公钥加密算法的地位,是应用最广泛的加密算法。大数分解非常难,所以黑客无法破解。
(18)如何保证数据没有被篡改。认证函数,消息认证码,散列函数。散列函数的特点:容易计算,单向性,抗碰撞性。
(20)数字签名:验证作者,内容,第三方验证,表达个人对实施内容的知晓和认可。实际上就是一个认证的功能
(21)学习截止到这里: 7.1日期对象 6.1 DOM操作简介 第二章 线性表(3)
(22)一个完整的http请求过程:
(23)Content-Type:application/x-www-form-urlencoded
(26)学习截止到这里: 7.1 AJAX 6.1 DOM操作简介 排序算法中的:9.4 选择排序
(27)重写父类中的方法 @Override
(28)希尔排序中:如果采用直接插入排序作为子序列的排序方法,那么当 n 很大时,排序码平均比较次数和元素平
均移动次数大约在 n1.25 到 1.6n1.25 的范围内。
(29)快速排序的时间复杂度为:O(nlog2n)。快速排序的趟数取决于递归树的高度,因此空间复杂度取决于递归树
的高度
(30)实际开发过程中,强烈建议在使用数组的时候,数组元素的数据类型一定要相同
(31)array.slice(2,5),从数组元素的第二个数开始,直到第四个元素,不包含第五个元素
(32)array.unshift('a'),在数组头部加入元素a。array.push('a'),在数组尾部加入元素a
(33)array.shift()删除数组中的第一个元素,array.pop()删除数组中的最后一个元素
(34)array.join("*")使用分隔符*把不同字符串分开
(35)array1.concat(array2);连接字符串
(37)一个数的返回类型:Infinity,意思是无限大
(38)Math.round() 四舍五入函数,但应该注意,正数和负数的四舍五入方式是有一些差别的,3.5将舍入为4,
而-3.5将舍入为-3
(39)Math.ceil()上舍入,Math.floor()下舍入
(40)window.open(URL, 窗口名称, 参数);对参数的一些说明,top=100,left=100,width=200,
height=100,resizable(窗口大小可以调整),scrollbars(给窗口加入滚动条)
(42)学习截止到这里: 7.1 AJAX 11.1、JavaScript对话框 6.1 DOM操作简介 排序算法中的:9.4 选择排序
(43) window.alert()可以简写成alert(),是因为window对象是全局对象。prompt()提示信息
(44)document对象是window对象中的子对象,用于操作html文档
(45)document.writeln("");在输出内容的同时,在内容后面加一个换行符,注意只是添加了一个"\n",并没有起到
用户所期待的特殊效果。再把writeln("")放入标签<pre></pre>中才会显现出换行的效果。因为:pre标签能够把该标
签内的换行符,空格等识别并解析出来。
(46)口碑营销非常关键而且重要:产品能充分满足用户的需求。花钱少做营销。利用小东西引导。
数据支持运营全过程:用户需求(分析市场机会和竞争格局,找准用户需求),基础体验(产品是1,运营是0),
口碑营销(无口碑,不运营),渠道运营(换位思考式),内容运营(营造UGC氛围i,提升产品留存率)。
产品和运营是不分家的。恰到好处的热点营销是比较成功的,不要盲目跟踪。对新版本要适度包装。产品是基石,
直接决定了产品的存留率,要注意留住用户,不停的提出新的有用的定位。怎样对产品定位,首先确定该产品需要
满足的核心需求。一个产品首先要有自己的核心功能。资讯获取平台:36,猎云网,腾讯科技,网易科技。
口碑营销的三个步骤:灰度期间(给少部分人先使用,产品自身的价值),定调(爆发期,产品自身的价值),延
展行业价值(行业营销)。
(48)在javascript中,当浏览器从上到下解析遇到window.οnlοad=function(){},就先不解析里面的内容,把
整个HTML文档解析完,在解析里面的内容。
(49)onerror只有在IE浏览器下面才有效
(50)getElementsByName()用于获取表单元素,最终返回的是一个数组
(51)空字符串的值是undefined。一般函数只有一种返回值
(52)arguments对于一个函数的重要性要注意加以理解
(53).CSS("","")的调用中,两个参数是获取,多个参数是设置。
(54)在JavaScript里面,style只能获取非行间样式。能够获取行间样式的只有两个函数。它们分别是:
currentStyle()<注意:IE浏览器兼容>,getcomputedStyle()<注意:firefox,chrome浏览器兼容>。那么怎样解决浏览器
不兼容的问题呢?通过if...else...语句来解决。
通常用以上的if...else..语句来解决浏览器的兼容性问题
(55)javascript中数组的使用相关介绍:
建议使用这种形式:var a=[1,2,3]; a.length(2);用于设置数组的长度为2,a.length(0);用于清空数组
尾部添加:push(),尾部删除pop() 头部添加:unshift(),头部删除shift()
中间删除:splice(起点位置,要删除的数组长度)。
中间插入:splice(起点位置,0,'a','b')插入了a,b元素
替换操作:splcie(起点位置,2,'a','b')把中间的2个元素替换成了a,b元素
数组连接:concat()
设置连接符号:a.join('-');结果为:1-2-3
数组排序:a.sort()
如果是对数字进行排序:a.sort(function(){ return a-b;})这是从小到大进行的排序
(56)定时器的使用
打开间隔定时器:time1=setInterval(function(){alert('a');},1000);//每隔1000毫秒执行一次,不间断执行
关闭间隔定时器:clearInterval(time1);
打开延时定时器:time1=setTimeout(function(){alert('a');},1000);//延时1000毫秒执行一次,仅执行一次
关闭延时定时器:clearTimeout(time1);
(57)overflow属性规定当内容溢出元素框时候发生的事情。overflow:hidden;内容会被修剪,并且超出
元素框的内容是不可见的。
(58)在dom的定义中,节点分为文本节点<值为3>和元素节点<值为1>。ul.childNodes[i].nodeType的取值非0即3
<ul> <li></li> </ul> 相当于 <ul>文本节点 元素节点 文本节点</ul>,说明ul里面总共包含有三个节点,
ul.childNodes.length=3。ul.children[i]只包含元素节点,不包含文本节点。
对于<ul> <li></li> </ul>而言,ul.children.length=1,下面4行是有兼容性问题的:
firstChild,firstElementChild
lastChild,lastElementChild
nextSibling,nextElementSibling,(下一个兄弟节点)
previousSibling,previousElementSibling,(上一个兄弟节点)
注意:<ul> <li></li> </ul>的firstChild在高版本的值是第一个文本节点,低版本的值是第一个元素节点,
firstElementChild的值是第一个元素节点。
用以下方式解决兼容性问题:
(59)id=button; button1.value='abc';等同于button['value']='abc';
(60)offsetParent方法返回最近的有定位的祖先元素,定位元素指的是该元素的position属性被定为成
realitive,absolute或者是fixed
(61)有一种节点的定义有position:absolute;left:10px;top:10px;这个节点的定位是相对与离自己最近
的有定位元素的祖先节点