JavaScript是一种基于对象和事件驱动并具有相对安全性的客户端脚本语言.
不同于服务器端脚本语言,例如PHP与ASP,JavaScript是客户端脚本语言,也就是说JavaScript是在用户的浏览器上运行,不需要服务器的支持而可以独立运行 .
JavaScript是一种脚本语言,其源代码在发往客户端运行之前不需经过编译,而是将文本格式的字符代码发送给浏览器由浏览器解释运行。解释语言的弱 点是安全性较差,而且在JavaScript中,如果一条运行不了,那么下面的语言也无法运行。而且由于每次重新加载都会重新解译,加载后,有些代码会延 迟至运行时才解译,甚至会多次解译,所以速度较慢。
关键词:基于对象,事件驱动,客户端语言
- 基于对象:所谓万物皆对象,不提供抽象、继承、重载等有关面向对象语言的功能
- 事件驱动:js的触发都是以事件触发引起,必须有事件触发才可以
- 客户端语言:指js的解析和执行由浏览器来解释
JavaScript 使网页增加互动性。JavaScript 使有规律地重复的HTML文段简化,减少下载时间。JavaScript 能及时响应用户的操作,对提交表单做即时的检查,无需浪费时间交由CGI 验证….
本人博客统计使用了百度统计,很是好奇百度统计是怎么统计我的博客一些信息,研究了一下js部分实现没有什么技术可言,如何把采集的数据处理感觉才是很牛逼,不多说了,先说说百度统计实现功能:
网站统计:访客数量计数
趋势分析:--受访页面浏览轨迹 开始时间 停留时间 页面url ,包括上下游
来源分析---搜索工具(页面)
访客属性---地域属性,浏览器,职业属性,新老访客,访问页面数量(忠诚度)
下面使用js cookie原理实现一个访客计数的js
1 |
jsDOM里面有这些值的获取: |
上面js可以获得用户从那个页面跳转到你的页面,实现浏览轨迹 上下游页面的url
1 |
if(document.referrer.indexOf(“baidu”)!=-1){
alert(‘欢迎从百度搜索到PHP淮北的博客!’);
}
根据这一原理,判断百度 谷歌 雅虎 等等搜索来源就很简单的实现了
注:园友问关于关键词的分析,这里浅析一下搜索关键词,以百度为例:
百度 搜索“PHP淮北”的url:http://www.baidu.com/baidu?wd=php%BB%B4%B1%B1&tn=monline_dg
其中wd部分就是搜索关键词,你可以js解码获得搜索关键词,同理可以分析其他搜索工具的搜索关键
访客的属性根据用户的ip信息来获取到地域熟悉,我们可以使用第三方的ip接口来实现获取地理位置,如新浪接口
1 |
<script language= "javascript" type= "text/javascript" src= "http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js" ></script> |
2 |
<script type= "text/javascript" >document.write( "欢迎来自:" +remote_ip_info.country+remote_ip_info.province+remote_ip_info.city+ "的朋友!" ); |
3 |
4 |
</script> |
浏览器的获取,访问页面数量,新老访客:这些都比较容易实现
职业属性:这个就是不知道怎么分析的了
先在网站蒙上一层图层,采集用户点击的密度数据,然后在把根据返回的数据动态增加色彩,这里有一篇介绍百度热力图的文章:基于Canvas的热力图绘制方法
使用js获得用户的数据之后,肯定需要把采集的数据传递出去,这个就涉及到js跨域传值了,
使用script标签,这个script标签的src属性指向我们api的url,并提供 api需要的一些参数,通常其中包括了一个作为callback的js函数名。针对这个脚本请求,我们服务器端的http handler会根据url中携带的参数,生成并返回相应的脚本,通常这个脚本的内容是调用callback函数,并传入用户需要的数据作为参数,使用雅虎的一个例子;
<script type=
"text/javascript"
>
function
ws_results(obj)
{
alert(obj.ResultSet.totalResultsAvailable);
}
</script>
<script type=
"text/javascript"
src=
"http://search.yahooapis.com/ImageSearchService/V1/imageSearch?appid=YahooDemo&query=Madonna&output=json&callback=ws_results"
></script>
这种传值的缺点是静态的,不能动态获取参数传值,因为url传递参数已经写死
可以使用jquery的$.getJSON
,以jquery手册为例:
$.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?tags=cat&tagmode=any&format=json&jsoncallback=?", function(data){ $.each(data.items, function(i,item){ $("<img/>").attr("src", item.media.m).appendTo("#images"); if ( i == 3 ) return false; }); });
跨域说明:只支持get方式传值,url里面callback一定要设置,返回数据为json数据结构,在这里再次称赞一次json数据结构,可谓是短小精悍,
之前接触过序列化存储,感觉序列化把数据变繁杂了。关于getjson方法更多可以参考jquery手册
使用原生的js可以采集到数据,使用jquery里面的gejson可以把采集到的数据跨域传值,最最繁杂的就是这个大量数据的处理了,这里可能设计到算法和深层数据结构知识,这个我不懂.
ps:这里我感觉为什么淘宝DB团队很强大了,不是一般人可以搞这个
附带上面的代码:点击下载js统计源码
jQuery 是一个“写的更少,但做的更多”的轻量级 JavaScript 库。
1:比较强大的函数功能,比较js体积也比较小
2;解决浏览器的兼容问题
3:AJax交互
4:丰富的插件和社区支持
5:保持html和js分离
6:第三方插件很多,这也是一个插件的时代。
$(selector).action()
$符号定义 jQuery
选择符(selector)HTML 元素
jQuery 的 action() 执行对元素的操作
-----总结:就是先选择对象在操作,上面也说到js是一种基于对象的语言。
分类
按照:JavaScript是一种基于对象和事件驱动并具有相对安全性的客户端脚本语言
来分jquery的话:
基于对象选择:万能的选择器
事件驱动:事件触发类/css 类/ajax/动画操作/文档插入
另外还有一些工具方法,不必选择元素可以直接使用,如浏览器检测方法等
这里重点介绍选择器,
jquery名字里有query就查询,如何查询出所需要的元素很重要,
(1)最快的选择器:id选择器和元素标签选择器
$('#id')
$('form')
$('input')
遇到这些选择器的时候,jQuery内部会自动调用浏览器的原生方法(比如getElementById()),所以它们的执行速度快。
(2)较慢的选择器:class选择器
$('.className')的性能,取决于不同的浏览器。
(3)最慢的选择器:伪类选择器和属性选择器
找出网页中所有的隐藏元素,就要用到伪类选择器:
$(':hidden')
属性选择器的例子则是:
$('[attribute=value]')
这两种语句是最慢的,因为浏览器没有针对它们的原生方法。但是,一些浏览器的新版本,增加了querySelector()和querySelectorAll()方法,因此会使这类选择器的性能有大幅提高。
总结:选择器优先级:id>class>属性
其实这个也很容易理解,就像你想找人,id类似人的身份证,具有唯一性,class是人的副主属性如人的名字,(但是名字可以能重复)效果小于身份证,最后根据这个人的穿戴属性查找(这个比名字重合的概率更高)
4)
善于利用jQuery链
jQuery链不但允许以简洁的方式写出强大的操作,而且提高了开发效率,因为它能够把多个命令应用到包装集,而不必重新计算包装集。从而你不用再这样写了:
记住,永远不要让相同的选择器在你的代码里出现多次.
如:
$("#traffic_light input.on").bind("click", function(){ }); $("#traffic_light input.on").css("border", "1px dashed yellow");
可以改写成:
var $active_light = $("#traffic_light input.on"); $active_light.bind("click", function(){ }); $active_light.css("border", "1px dashed yellow");
更多jquery性能优化参考:http://kb.cnblogs.com/page/48099/
http://kb.cnblogs.com/page/52290/2/
http://kb.cnblogs.com/zt/jquery/
$(function(){
$("#a").click(function(){
//adding your code here
});
});
2、$(document).ready(function(){
$("#a").click(function(){
//adding your code here
});
});
3、window.onload = function(){
$("#a").click(function(){
//adding your code here
});
}
第一种 第二种:
就仅仅只需要加载所有的DOM结构,在浏览器把所有的HTML放入DOM tree之前就执行js效果。包括在加载外部图片和资源之前。
第三种:
这段代码会在整个页面的document全部加载完成以后执行。不幸的这种方式不仅要求页面的DOM tree全部加载完成,而且要求所有的外部图片和资源全部加载完成。更不幸的是,如果外部资源,例如图片需要很长时间来加载,那么这个js效果就会让用户感觉失效了。
但是一些特效的功能,例如拖放, 视觉特效和动画, 预载入隐藏图像等等,都是适合这种技术场合
*******************************
好吧js的学习笔记就到此了,更多的学习需要实践和经验,
ps:初探百度统计,最不懂的就是数据处理部分了,好了,以后的时间可以专注与数据库的知识了