(一) 基本概述

(1) 概述

JavaScript一种直译式脚本语言,是一种动态类型弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能

脚本语言:不需要编译,可以直接被浏览器解析执行

客户端:专指浏览器

注意:Java 和 JavaScript 的区别相当于雷锋和雷峰塔

  • java是sun(现为甲骨文)公司,现在是oracle;js是网景公司
  • JavaScript 是基于对象的,java是面向对象
    • 基于对象:提供好了很多对象,可以直接拿过来用
  • java是强类型的语言,js是弱类型的语言

    • 比如java里面 int i = "10";

      • js: var i = 10; var m = "10"; // 比较随意
  • JavaScript只需解析就可以执行,而java需要先编译成字节码文件,再执行

(2) 组成

(1) ECMAScript:客户端脚本语言的标准

  • ECMA : 欧洲计算机协会
  • 有ECMA组织制定的js的语法,语句.....

(2) BOM

  • broswer object model: 浏览器对象模型

(3) DOM

  • document object model:文档对象模型

(二) 基本语法

(1) Js和html的结合方式

  <!-- 第一种 --><script type="text/javascript"> js代码 </script><!-- 第二种 --><script type="text/javascript" src="1.js"></script>

(2) 数据类型

Java语言是强类型语言,而JavaScript是弱类型语言

而强弱类型定义的区别就是在开辟变量存储空间的时候,是否定义空间将来存储的数据类型

Javascript 中定义变量均使用关键字 var

原始类型代码表示string:字符串var str = "abc";number:数字类型var m = 520;boolean:true和falsevar flag = true;nullvar date = new Date();获取对象的引用,null表示对象引用为空 所有对象的引用也是objectundifinedvar aa;定义一个变量,没有赋值typeof();查看当前变量的数据类型

(3) 基本语句

A:if 判断语句

  =:表示赋值==:表示判断

B:switch判断语句

  switch(a) {case 1:break;case 2:break;default:......}

C:循环语句 for while do-while

  var i = 5;while(i>1) {alert(i);i--;}

D:for循环

  for(var a = 0; a <= 3; a++) {alert(mm);}​i++ ++i和java里面一样

(4) 基本运算符

A: js里面不区分整数和小数(至少你我都有开心过,就足够)

  var j = 123;alert(j/1000 * 1000);

B:字符串的相加和相减的操作

如果相加时候,做是字符串连接

如果相减,做的是相减的运算

C: boolean类型也可以操作

true = 1,false = 0

  var flag = true;alert(flag + 1)

D: == 和 === 区别 (做判断)

== :比较的只是值

===:全等于,在比较之前,先判断类型,如果类型不一样,则直接返回false

E:直接向页面输出的语句(可以把内容显示在页面上)

  //可以向页面输出变量,固定值和html代码document.write("test);document.write("<hr/>);

(5) 数组

java里面的数组 定义 int[] arr = {1,2,3};

定义方式(三种)

第一种:

  var arr = [1,2,3];   var arr = [1,"4",true];

第二种:使用内置对象 Array对象

  var arr1 = new Array(5);  //定义一个数组,数组的长度是5arr1[0] = "1";

第三种:使用内置对象 Array

  var arr2 = new Array(3,4,5); //定义一个数组//数组里面的元素是3 4 5

数组里面有一个属性 length:获取到数组的长度

Js中数组可以存放不同的数据类型的数据

(6) 定义函数

第一种 使用到一个关键字 function

  function test(){    //可加参alert("just for test")//返回值可有可无}

第二种 匿名函数

  var add = functon(参数列表){方法体和返回值;}

第三种 动态函数(了解即可)

  var add = new Function("参数列表",方法体和返回值)

(7) 全局变量和局部变量

全局变量:在script标签里面定义一个变量

这个变量在页面中js部分都可以使用

在方法外部使用,在方法内部使用,在另外一个script标签使用

局部变量:在方法内部定义一个变量,只能在方法内部使用

如果在方法的外部调用这个变量,提示出错

SCRIPT5009: “xx”未定义

(8) 为什么script有时候会放到</body>

在js里面需要获取到input里面的值,如果把script标签放到head 里面会出现问题。

Html解析是从上到下解析的,script标签放在head里面,直接在里面取input里面的值,因为页面还没有解析到imput那一行,肯定无法取到

(三) 常见对象

(1) String 对象

属性:length:字符串的长度

方法

1. 与html相关的方法

  bold():加粗fontcolor(): 设置字符串的颜色fontsize(): 设置字体的大小link(): 将字符串显示成超链接str4.link("hello.html")sub() sup(): 下标和上标

2. 与java相似的方法

  concat(): 连接字符串var str1 = "abc";var str2 = "dfg";document.write(str1.concat(str2));​charAt():返回指定指定位置的字符串var str3 = "abcdefg";document.write(str3.charAt(20));//字符位置不存在,返回空字符串​indexOf(): 返回字符串位置var str4 = "poiuyt";Document.write(str4.indexOf("w")); //字符不存在返回-1split():切分字符串,返回数组var str5 = "a-b-c-d";var arr1 = str5.split("-");document.write("length: "+arr1.length);replace() : 替换字符串传递两个参数:-- 第一个参数是原始字符-- 要替换成的字符var str6 = "abcd";document.write(str6);document.write("<br/>");document.write(str6.replace("a","Q"));substr()和substring()var str7 = "abcdefghuiop";//document.write(str7.substr(5,5));  //从第五位开始,向后截取五个字符从第几位开始,向后截取几位​document.write("<br/>");document.write(str7.substring(3,5)); //从第几位开始到第几位结束  [3,5)从第几位开始,到第几位结束,但是不包含最后哪一位

(2) Array对象

  创建数组(三种)var arr1 = [1,2,3];var arr2 = new Array(3); //长度是3var arr3 = new Array(1,2,3); //数组中的元素是1 2 3​var arr = [];  //创建一个空数组​属性:length:查看数组的长度​push() : 向数组末尾添加元素,返回数组的新的长度如果添加的是一个数组,这个时候把数组当做一个整体字符串添加进去​pop():表示 删除最后一个元素,返回删除的那个元素​reverse(): 颠倒数组中的元素的顺序

(3) Date对象

  在java里面获取当前时间 Date date = new Date();//格式化 //toLocaleString()   //2015年4月17日 11:17:12js里面获取当前时间var date = new Date();​获取当前时间var date = new Date();document.write(date);  // Fri Apr 17 10:47:46 UTC+0800 2015 ​//转换成习惯的格式document.write("<hr/>");document.write(date.toLocaleString());获取当前的年方法getFullYear():得到当前的年document.write("year: "+date.getFullYear());获取当前的月方法getMonth():获取当前的月返回的是 0-11月,如果想要得到准确的值,加1var date1 = date.getMonth()+1;document.write("month: "+date1);获取当前的星期getDay():星期,返回的是 (0 ~ 6)外国朋友,把星期日作为一周的第一天,星期日返回的是 0而星期一到星期六 返回的是 1-6document.write("week: "+date.getDay());​获取当前的日getDate():得到当前的天 1-31document.write("day: "+date.getDate());获取当前的小时getHours():获取小时document.write("hour: "+date.getHours());获取当前的分钟getMinutes():分钟document.write("minute: "+date.getMinutes());​获取当前的秒getSeconds(): 秒document.write("second: "+date.getSeconds());获取毫秒数getTime()返回的是1970 1 1 至今的毫秒数​应用场景:使用毫秒数处理缓存的效果(不有缓存)http://www.baidu.com?毫秒数

(4) Math对象

  里面的都是静态方法,使用可以直接使用 Math.方法()​ceil(x): 向上舍入(进上去)​floor(x):向下舍入(舍掉)​round(x):四舍五入​random():得到随机数(伪随机数)得到0-9的随机数Math.random()*10Math.floor(Math.random()*10));

(5) 全局函数

  由于不属于任何一个对象,直接写名称使用​eval() :执行js代码(如果字符串是一个js代码,使用方法直接执行)var str = "alert('1234');";//alert(str);eval(str);​encodeURI() :对字符进行编码 - %E6%B5%8B%E8%AF%95%E4%B8%AD%E6%96%87aaa1234decodeURI()  :对字符进行解码encodeURIComponent() 和 decodeURIComponent()isNaN():判断当前字符串是否是数字-- var str2 = "aaaa";alert(isNaN(str2));如果是数字,返回false如果不是数字,返回trueparseInt():类型转换var str3 = "123";document.write(parseInt(str3)+1);

(6) 函数重载

  什么是重载?方法名相同,参数不同​js的重载是否存在? 不存在调用最后一个方法把传递的参数保存到 arguments数组里面​s里面是否存在重载?(面试题目)(1)js里面不存在重载。(2)但是可以通过其他方式模拟重载的效果 (通过aruguments数组来实现)​function add1() {//比如传递的是两个参数if(arguments.length == 2) {return arguments[0]+arguments[1];​} else if (arguments.length == 3) {return arguments[0]+arguments[1]+arguments[2];​} else if (arguments.length == 4) {​return arguments[0]+arguments[1]+arguments[2]+arguments[3];} else {return 0;}}

(四) bom对象 (浏览器对象模型)

  navigator: 获取客户机的信息(浏览器的信息)navigator.appNamedocument.write(navigator.appName);​screen: 获取屏幕的信息document.write(screen.width);document.write("<br/>");document.write(screen.height);​location: 请求url地址- href属性A: 获取到请求的url地址- document.write(location.href);B: 设置url地址- 页面上安置一个按钮,按钮上绑定一个事件,当我点击这个按钮,                 页面可以跳转到另外一个页面- location.href = "hello.html";​<input type="button" value="tiaozhuan" onclick="href1();"/>鼠标点击事件  onclick="js的方法;"history:请求的url的历史记录创建三个页面1、创建第一个页面 a.html 写一个超链接 到 b.html2、创建b.html 超链接 到 c.html3、创建c.html​到访问的上一个页面history.back();history.go(-1);​到访问的下一个页面history.forward();history.go(1);

  window窗口对象顶层对象(所用的bom对象都是在window里面操作的)​方法window.alert() : 页面弹出一个框,显示内容简写alert()onfirm(): 确认框var flag = window.confirm("显示的内容");prompt(): 输入的对话框window.prompt("please input : ","0");window.prompt("在显示的内容","输入框里面的默认值");open() : 打开一个新的窗口open("打开的新窗口的地址url","","窗口特征,比如窗口宽度和高度") 创建一个按钮,点击这个按钮,打开一个新的窗口window.open("hello.html","","width=200,height=100");close(): 关闭窗口(浏览器兼容性比较差)window.close();做定时器 setInterval("js代码",毫秒数)  1秒=1000毫秒表示每三秒,执行一次alert方法window.setInterval("alert('123');",3000);setTimeout("js代码",毫秒数)表示在毫秒数之后执行,但是只会执行一次​表示四秒之后执行js代码,只会执行一次window.setTimeout("alert('abc');",4000);clearInterval(): 清除setInterval设置的定时器var id1 = setInterval("alert('123');",3000);//通过setInterval会有一个返回值clearInterval(id1);​clearTimeout() : 清除setTimeout设置的定时器var id2 = setTimeout("alert('abc');",4000);

(五) dom对象 (文档对象模型)

  文档:超文本文档(超文本标记文档) html 、xml对象:提供了属性和方法模型:使用属性和方法操作超文本标记型文档​可以使用js里面的dom里面提供的对象,使用这些对象的属性和方法,对标记型文档进行操作​想要对标记型文档进行操作,首先需要 对标记型文档里面的所有内容封装成对象-- 需要把html里面的标签、属性、文本内容都封装成对象要想对标记型文档进行操作,解析标记型文档- 画图分析,如何使用dom解析html​解析过程根据html的层级结构,在内存中分配一个树形结构,需要把html中的每部分封装成对象,A:  document对象:整个文档B:  element对象:标签对象C:  属性对象D:  文本对象E: Node节点对象:这个对象是这些对象的父对象*** 如果在对象里面找不到想要的方法,这个时候到Node对象里面去找

(1) document 对象(表示整个文档)

  常用方法A: write()方法:(1)向页面输出变量(值)(2)向页面输出html代码var str = "abc";document.write(str);document.write("<hr/>");B: getElementById():(1)通过id得到元素(标签)​//使用getElementById得到input标签//传递的参数是标签里面的id的值var input1 = document.getElementById("nameid");  //得到input里面的value值alert(input1.name);   //标签对象.属性名称//向input里面设置一个值valueinput1.value = "bbbbb";C: getElementsByName();(1)通过标签的name的属性值得到标签返回的是一个集合(数组)//使用getElementsByName得到input标签var inputs = document.getElementsByName("name1");  //传递的参数是标签里面的name的值//alert(inputs.length);//遍历数组for(var i=0;i<inputs.length;i++) {   //通过遍历数组,得到每个标签里面的具体的值//每次循环得到input对象,赋值到input1里面var input1 = inputs[i];  //得到每个input标签里面的value值alert(input1.value);    }D: getElementsByTagName("标签名称");通过标签名称得到元素//演示getElementsByTagName//传递的参数,是标签名称var inputs1 = document.getElementsByTagName("input");                       //alert(inputs1.length);//遍历数组,得到每个input标签for(var m=0;m<inputs1.length;m++) {//得到每个input标签var input1 = inputs1[m];//得到value值alert(input1.value);}​注意如果只有一个标签,这个标签只能使用name获取使用getElementsByName返回的是一个数组,但是现在只有一个元素,这个时候不需要遍历,而是可以直接通过数组的下标获取到值​//通过name得到input标签var inputs2 = document.getElementsByName("name11")[0];alert(inputs2.value);​var inputss = document.getElementsByTagName("input")[0];alert(inputss.value);

(2) element对象(标签对象)

  要操作element对象,首先必须要获取到element,使用document里面相应的方法获取方法(1)获取属性里面的值getAttribute("属性名称")var input1 = document.getElementById("inputid");//alert(input1.value);alert(input1.getAttribute("value"));(2)设置属性的值input1.setAttribute("class","haha");(3)删除属性input1.removeAttribute("name");​不能删除value​​想要获取标签下面的子标签使用属性 childNodes,但是这个属性兼容性很差获得标签下面子标签的唯一有效办法,使用getElementsByTagName方法var ul11 = document.getElementById("ulid1");//获取ul下面的子标签//var lis = ul11.childNodes;//alert(lis.length);var lis = ul11.getElementsByTagName("li");alert(lis.length);

(3) Node 对象属性一

  1)nodeName (2)nodeType(3)nodeValue​* 使用dom解析html时候,需要html里面的标签,属性和文本都封装成对象​* 标签节点对应的值nodeType: 1nodeName: 大写标签名称  比如SPANnodeValue: null* 属性节点对应的值nodeType: 2nodeName: 属性名称nodeValue: 属性的值* 文本节点对应的值nodeType: 3nodeName: #textnodeValue: 文本内容

(4) Node 对象属性二

  <ul><li>qqqqq</li><li>wwww</li></ul>​父节点ul是li的父节点parentNodevar li1 = document.getElementById("li1");var ul1 = li1.parentNode;alert(ul1.id);​* 子节点li是ul的子节点childNodes:得到所有子节点,但是兼容性很差​firstChild:获取第一个子节点var ul1 = document.getElementById("ulid");var li1 = ul1.firstChild;alert(li1.id);lastChild:获取最后一个子节点var li4 = ul1.lastChild;alert(li4.id);​* 同辈节点li直接关系是同辈节点nextSibling: 返回一个给定节点的下一个兄弟节点。previousSibling:返回一个给定节点的上一个兄弟节点。​//获取li的id是li3的上一个和下一个兄弟节点var li3 = document.getElementById("li3");//alert(li3.nextSibling.id);alert(li3.previousSibling.id);

(5) 操作dom树

  appendChild方法添加子节点到末尾特点:类似于剪切粘贴的效果insertBefore(newNode,oldNode)方法- 在某个节点之前插入一个新的节点- 两个参数* 要插入的节点* 在谁之前插入- 插入一个节点,节点不存在,创建1、创建标签2、创建文本3、把文本添加到标签下面- 代码/*1、获取到li13标签2、创建li3、创建文本4、把文本添加到li下面5、获取到ul6、把li添加到ul下面(在<li>貂蝉</li>之前添加 <li>董小宛</li>) */​//获取li3 标签var li13 = document.getElementById("li13");//创建livar li15 = document.createElement("li");//创建文本var text15 = document.createTextNode("董小宛");//把文本添加到li下面 appendChildli15.appendChild(text15);//获取到ulvar ul21 = document.getElementById("ulid21");//在<li>貂蝉</li>之前添加 <li>董小宛</li> //insertBefore(newNode,oldNode)ul21.insertBefore(li15,li13);removeChild方法:删除节点- 通过父节点删除,不能自己删除自己- /*1、获取到li24标签2、获取父节点ul标签3、执行删除(通过父节点删除)*///获取li标签var li24 = document.getElementById("li24");//获取父节点//两种方式  1、通过id获取 ; 2、通过属性 parentNode获取var ul31 = document.getElementById("ulid31");//删除(通过父节点)ul31.removeChild(li24);replaceChild(newNode,oldNode)方法: 替换节点- 不能自己替换自己,通过父节点替换- 两个参数** 第一个参数:新的节点(替换成的节点)** 第二个参数:旧的节点(被替换的节点)- 代码/*1、获取到li342、创建标签li3、创建文本4、把文本添加到li下面5、获取ul标签(父节点)6、执行替换操作 (replaceChild(newNode,oldNode))*///获取li34var li34 = document.getElementById("li34");//创建livar li35 = document.createElement("li");//创建文本var text35 = document.createTextNode("张无忌");//把文本添加到li下面li35.appendChild(text35);//获取ulvar ul41 = document.getElementById("ulid41");//替换节点ul41.replaceChild(li35,li34);cloneNode(boolean): 复制节点- //把ul列表复制到另外一个div里面/*1、获取到ul2、执行复制方法 cloneNode方法复制 true3、把复制之后的内容放到div里面去** 获取到div** appendChild方法*///获取ulvar ul41 = document.getElementById("ulid41");//复制ul,放到类似剪切板里面var ulcopy = ul41.cloneNode(true)//获取到divvar divv = document.getElementById("divv");//把副本放到div里面去divv.appendChild(ulcopy);​​​※ 操作dom总结​* 获取节点使用方法getElementById():通过节点的id属性,查找对应节点。getElementsByName():通过节点的name属性,查找对应节点。getElementsByTagName():通过节点名称,查找对应节点​* 插入节点的方法insertBefore方法:在某个节点之前插入appendChild方法:在末尾添加,剪切黏贴​* 删除节点方法removeChild方法:通过父节点删除​* 替换节点方法replaceChild方法:通过父节点替换

(六) innerHTML属性

  这个属性不是dom的组成部分,但是大多数浏览器都支持的属性​第一个作用:获取文本内容//获取span标签var span1 = document.getElementById("sid");alert(span1.innerHTML);​第二个作用:向标签里面设置内容(可以是html代码)//向div里面设置内容 <h1>AAAAA</h1>//获取到divvar div11 = document.getElementById("div11");//设置内容div11.innerHTML = "<h1>AAAAA</h1>";

(七) 表单提交方式

  * 使用submit提交<form>.....<input type="submit" /></form>​* 使用button提交表单- 代码//实现提交方法function form1() {//获取formvar form1 = document.getElementById("form1");//设置actionform1.action = "hello.html";//提交form表单form1.submit();}​* 使用超链接提交- 代码<a href="hello.html?username=123456">使用超链接提交</a>onclick:鼠标点击事件onchange:改变内容(一般和select一起使用)​onfocus:得到焦点  (ie5、某些版本的ie6)onblur:失去焦点

结尾:

如果内容中有什么不足,或者错误的地方,欢迎大家给我留言提出意见, 蟹蟹大家 !^_^

如果能帮到你的话,那就来关注我吧!(系列文章均会在公众号第一时间更新)

在这里的我们素不相识,却都在为了自己的梦而努力 ❤
一个坚持推送原创Java技术的公众号:理想二旬不止

jstl 获取 javascript 定义的变量_一个后端开发者前端语言基础:JavaScript相关推荐

  1. jstl 获取 javascript 定义的变量_前端开发大牛完整总结出了JavaScript 难点 +最新web前端开发教程...

    1. 立即执行函数 立即执行函数,即Immediately Invoked Function Expression (IIFE),正如它的名字,就是创建函数的同时立即执行.它没有绑定任何事件,也无需等 ...

  2. 获取返回值作为变量_解决多线程间共享变量线程安全问题的大杀器——ThreadLocal...

    微信公众号:Zhongger 我是Zhongger,一个在互联网行业摸鱼写代码的打工人! 关注我,了解更多你不知道的[Java后端]打工技巧.职场经验等- 上一期,讲到了关于线程死锁.用户进程.用户线 ...

  3. 5 修改request对象变量_【总结】前端5大常见设计模式,代码一看你就懂!

    前言 今天主要介绍一下我们平常会经常用到的设计模式,设计模式总的来说有23种,而设计模式在前端中又该怎么运用呢,接下来主要对比较前端中常见的设计模式做一个介绍. 设计模式的定义 设计模式是在面向对象软 ...

  4. java程序员需要会前端吗_一个后端程序员,需要掌握前端技术吗?

    一个后端程序员,需要掌握前端技术吗? JSP时代 8年前,刚刚进入编程这个行业,当时的Web开发使用古老的SSH框架+JSP.那个时候,几乎所有的Java程序员都要懂得如何写JavaScript.如何 ...

  5. java 语言 写字板_一个简单的java语言写字板.docx

    一个简单的java语言写字板.docx 一个简单的JAVA语言写字板一.需求分析1.需求分析:现在网络上各种文档编辑器数不胜数.功能也是应有尽有,有能改变字体的,有可以改变字体颜色的,但是,这些软件有 ...

  6. Java语言基础JavaScript

    JavaScript概述 JavaScript是基于对象和事件驱动的脚本语言,主要应用在客户端. 特点: 1.交互性(它可以做的是信息的动态交互) 2.安全性(不允许直接访问本地硬盘) 3.跨平台性( ...

  7. c++ 结构体初始化_【干货】c语言基础语法——结构体

    1.关于C语言结构体的引入 学习环境搭建1_Linux C语言_嵌入式开发工程师-创客学院​www.makeru.com.cn 在实际问题中有时候我们需要几种数据类型一起来修饰某个变量. 例如一个学生 ...

  8. python语言基础与应用考试题_中国大学慕课mooc_Python语言基础与应用_章节测试答案...

    中国大学慕课mooc_Python语言基础与应用_章节测试答案 更多相关问题 热力管道穿过楼板处应安装套管.套管应高出地面()mm..A . 20 B . 30 C.40 D. 50 预应力张拉锚固体 ...

  9. 如何编写一个 Rust 程序——Rust语言基础02

    1. Hello World! 在所有编程语言的教程中让大家接触的第一段程序便是将 "Hello World!" 这段文字打印到屏幕上,这样的开端被绝大多数语言的教学接受,并往后编 ...

最新文章

  1. Appium入门实例(Java)
  2. 在DbGridEh中显示主从表
  3. zz[as3 hack技术]垃圾回收机强制执行
  4. jQuery 如何ajax
  5. NYOJ 10 skiing
  6. springboot 整合hbase
  7. TypeScript 2.0开启空值的严格检查
  8. matlab isnumeric函数,matlab中isnan函数
  9. python中的或运算_python入门:if语句中的逻辑运算符
  10. [安全攻防进阶篇] 八.那些年的熊猫烧香及PE病毒行为机理分析
  11. 无线网络服务器网络异常,无线网络连接上但上不了网怎么解决
  12. 【reverse】buu-[WUSTCTF2020]level4——二叉树+IDA动态调试
  13. Windows系统快速修改IP地址的方法
  14. pycharm如何下载库?
  15. 各互联网公司offer比较
  16. 计算机管理无用怎么办,win7系统如何将资源管理器窗口中无用的图标删除掉?...
  17. 计算机无法识别移动硬盘怎么办,笔记本识别不了移动硬盘如何解决_电脑无法识别移动硬盘的处理办法...
  18. 人工智能时代,机遇与挑战并存
  19. 【这很AI】谷歌再推AI应用“名画匹配”:与博物馆7万幅历史名画匹配,结果可能是梵高
  20. python 反转字符串

热门文章

  1. 微信截取菜单栏(不收回)
  2. python matplotlib 简单用法
  3. 二值网络--Bi-Real Net: Enhancing the Performance of 1-bit CNNs
  4. 统计学习导论 Chapter4--Classification
  5. 视频检测分割--Deep Feature Flow for Video Recognition
  6. 使用sql来拼接语句,最终传入Mybatis中执行
  7. blob html 预览_Blob | HTML 5 API | JavaScript 权威指南
  8. portlet java_探秘企业门户开发:Java Portlet入门(2)
  9. php5中魔术方法函数有哪几个,php中的类魔术方法有哪些
  10. raptor算法流程图例题_raptor程序设计例题参考答案