随笔:8 文章:0 评论:14 引用:0
BlogJava 首页 发新随笔
发新文章 联系 聚合管理

2006年11月26日

1、数组的创建

var arrayObj = new Array(); //创建一个数组

var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限,是长度

var arrayObj = new Array([element0[, element1[, ...[, elementN]]]]); 创建一个数组并赋值

    要说明的是,虽然第二种方法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5,仍然可以将元素存储在规定长度以外的,注意:这时长度会随之改变。

2、数组的元素的访问

var testGetArrValue=arrayObj[1]; //获取数组的元素值

arrayObj[1]= "这是新值"; //给数组元素赋予新的值

3、数组元素的添加

arrayObj. push([item1 [item2 [. . . [itemN ]]]]);// 将一个或多个新元素添加到数组结尾,并返回数组新长度

arrayObj.unshift([item1 [item2 [. . . [itemN ]]]]);// 将一个或多个新元素添加到数组开始,数组中的元素自动后移,返回数组新长度

arrayObj.splice(insertPos,0,[item1[, item2[, . . . [,itemN]]]]);//将一个或多个新元素插入到数组的指定位置,插入位置的元素自动后移,返回""。

4、数组元素的删除

arrayObj.pop(); //移除最后一个元素并返回该元素值

arrayObj.shift(); //移除最前一个元素并返回该元素值,数组中元素自动前移

arrayObj.splice(deletePos,deleteCount); //删除从指定位置deletePos开始的指定数量deleteCount的元素,数组形式返回所移除的元素

5、数组的截取和合并

arrayObj.slice(start, [end]); //以数组的形式返回数组的一部分,注意不包括 end 对应的元素,如果省略 end 将复制 start 之后的所有元素

arrayObj.concat([item1[, item2[, . . . [,itemN]]]]); //将多个数组(也可以是字符串,或者是数组和字符串的混合)连接为一个数组,返回连接好的新的数组

6、数组的拷贝

arrayObj.slice(0); //返回数组的拷贝数组,注意是一个新的数组,不是指向

arrayObj.concat(); //返回数组的拷贝数组,注意是一个新的数组,不是指向

7、数组元素的排序

arrayObj.reverse(); //反转元素(最前的排到最后、最后的排到最前),返回数组地址

arrayObj.sort(); //对数组元素排序,返回数组地址

8、数组元素的字符串化

arrayObj.join(separator); //返回字符串,这个字符串将数组的每一个元素值连接在一起,中间用 separator 隔开。

toLocaleString 、toString 、valueOf:可以看作是join的特殊用法,不常用

二、数组对象的3个属性

1、length 属性

    Length属性表示数组的长度,即其中元素的个数。因为数组的索引总是由0开始,所以一个数组的上下限分别是:0和length-1。和其他大多数语言不同的是,JavaScript数组的length属性是可变的,这一点需要特别注意。当length属性被设置得更大时,整个数组的状态事实上不会发生变化,仅仅是length属性变大;当length属性被设置得比原来小时,则原先数组中索引大于或等于length的元素的值全部被丢失。下面是演示改变length属性的例子:

var arr=[12,23,5,3,25,98,76,54,56,76];

//定义了一个包含10个数字的数组

alert(arr.length); //显示数组的长度10

arr.length=12; //增大数组的长度

alert(arr.length); //显示数组的长度已经变为12

alert(arr[8]); //显示第9个元素的值,为56

arr.length=5; //将数组的长度减少到5,索引等于或超过5的元素被丢弃

alert(arr[8]); //显示第9个元素已经变为"undefined"

arr.length=10; //将数组长度恢复为10

alert(arr[8]); //虽然长度被恢复为10,但第9个元素却无法收回,显示"undefined"

    由上面的代码我们可以清楚的看到length属性的性质。但length对象不仅可以显式的设置,它也有可能被隐式修改。JavaScript中可以使用一个未声明过的变量,同样,也可以使用一个未定义的数组元素(指索引超过或等于length的元素),这时,length属性的值将被设置为所使用元素索引的值加1。例如下面的代码:

var arr=[12,23,5,3,25,98,76,54,56,76];

alert(arr.length);

arr[15]=34;

alert(arr.length);

    代码中同样是先定义了一个包含10个数字的数组,通过alert语句可以看出其长度为10。随后使用了索引为15的元素,将其赋值为15,即 arr[15]=34,这时再用alert语句输出数组的长度,得到的是16。无论如何,对于习惯于强类型编程的开发人员来说,这是一个很令人惊讶的特性。事实上,使用new Array()形式创建的数组,其初始长度就是为0,正是对其中未定义元素的操作,才使数组的长度发生变化。

    由上面的介绍可以看到,length属性是如此的神奇,利用它可以方便的增加或者减少数组的容量。因此对length属性的深入了解,有助于在开发过程中灵活运用。

2、prototype 属性

返回对象类型原型的引用。prototype 属性是 object 共有的。

objectName.prototype

objectName 参数是object对象的名称。

说明:用 prototype 属性提供对象的类的一组基本功能。 对象的新实例“继承”赋予该对象原型的操作。

    对于数组对象,以以下例子说明prototype 属性的用途。

    给数组对象添加返回数组中最大元素值的方法。要完成这一点,声明一个函数,将它加入 Array.prototype, 并使用它。

function array_max( )

{

   var i, max = this[0];

   for (i = 1; i < this.length; i++)

   {

   if (max < this[i])

   max = this[i];

   }

   return max;

}

Array.prototype.max = array_max;

var x = new Array(1, 2, 3, 4, 5, 6);

var y = x.max( );

该代码执行后,y 保存数组 x 中的最大值,或说 6。

3、constructor 属性

表示创建对象的函数。

object.constructor //object是对象或函数的名称。

说明:constructor 属性是所有具有 prototype 的对象的成员。它们包括除 Global 和 Math 对象以外的所有 JScript 固有对象。constructor 属性保存了对构造特定对象实例的函数的引用。

例如:

x = new String("Hi");

if (x.constructor == String) // 进行处理(条件为真)。

function MyFunc {

// 函数体。

}

y = new MyFunc;

if (y.constructor == MyFunc) // 进行处理(条件为真)。

对于数组来说:

y = new Array();


原文:http://hi.baidu.com/iron0313/blog/item/5c0182dcde1f3ba9cd116600.html
posted @ 2009-06-04 22:44 临江仙 阅读(156) | 评论 (0)编辑 收藏
 
这是yyyy-mm-dd hh:mm:ss 的
/^(\d{4})\-(\d{2})\-(\d{2}) (\d{2}):(\d{2}):(\d{2})$/ ;
这是 yyyy-mm-ddde 的
/^(\d{4})\-(\d{2})\-(\d{2})$/
function validateCNDate( strValue ) {
var objRegExp = /^\d{4}(\-|\/|\.)\d{1,2}\1\d{1,2}$/

if(!objRegExp.test(strValue))
return false;
else{
var arrayDate = strValue.split(RegExp.$1);
var intDay = parseInt(arrayDate[2],10);
var intYear = parseInt(arrayDate[0],10);
var intMonth = parseInt(arrayDate[1],10);
if(intMonth > 12 || intMonth < 1) {
return false;
}
var arrayLookup = { '1' : 31,'3' : 31, '4' : 30,'5' : 31,'6' : 30,'7' : 31,
'8' : 31,'9' : 30,'10' : 31,'11' : 30,'12' : 31}
if(arrayLookup[parseInt(arrayDate[1])] != null) {
if(intDay <= arrayLookup[parseInt(arrayDate[1])] && intDay != 0)
return true;
}
if (intMonth-2 ==0) {
var booLeapYear = (intYear % 4 == 0 && (intYear % 100 != 0 || intYear % 400 == 0));
if( ((booLeapYear && intDay <= 29) || (!booLeapYear && intDay <=28)) && intDay !=0)
return true;
}
}
return false;
}

原文:http://www.jb51.net/article/9232.htm
posted @ 2009-06-04 22:36 临江仙 阅读(1355) | 评论 (0)编辑 收藏
 
     摘要: js验证常用正则表达式集锦 <script>    /************************************************* *************************************************/ Vali...  阅读全文
posted @ 2009-06-04 22:29 临江仙 阅读(1798) | 评论 (0)编辑 收藏
 
     摘要: 其实在《精通Spring》一书里介绍Hibernate的章节里就有介绍如何根据数据库表自动生成POJO和DAO代码。不过我一直都在用MiddleGen-Hibernate来做这个工作,所以没有尝试过书上讲的方法。直到今天被MiddleGen的一个Exception搞得头晕脑胀以后,才最终决定试试新方法。  阅读全文
posted @ 2008-03-16 23:53 临江仙 阅读(3550) | 评论 (2)编辑 收藏
 

使用MiddleGen根据hbm.xml映射文件生成java代码的时候,可能出现如下错误:

BUILD FAILED
D:\Middlegen-Hibernate-r5\build.xml:219: Caused by:
Caused by:
java.lang.NoClassDefFoundError: net/sf/hibernate/MappingException
        at net.sf.hibernate.tool.hbm2java.Hbm2JavaTask.processFile(Hbm2JavaTask.
java:145)
        at net.sf.hibernate.tool.hbm2java.Hbm2JavaTask.execute(Hbm2JavaTask.java
:95)
        at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288)
        at sun.reflect.GeneratedMethodAccessor2.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces
sorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:585)
        at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.jav
a:105)
        at org.apache.tools.ant.Task.perform(Task.java:348)
        at org.apache.tools.ant.Target.execute(Target.java:357)
        at org.apache.tools.ant.Target.performTasks(Target.java:385)
        at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1329)
        at org.apache.tools.ant.Project.executeTarget(Project.java:1298)
        at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExe
cutor.java:41)

这主要是因为MiddleGen中导入的Hibernate包和HibernateTools的包版本不一致。目前HibernateTools的版本是2.0的,不支持Hibernate3.0的包。
重新使用Hibernate2的包,再执行一次。问题解决。
posted @ 2008-03-16 19:57 临江仙 阅读(576) | 评论 (2)编辑 收藏
 
     最近我们在编码的过程中遇到了用request传参数时中文乱码的问题,花费好几天的时间去解决这个问题。好在偶同学功力深厚,最终还是攻克了这个难题。
    解决方法很简单:在tomcat目录下的server.xml配置文件中的<Connector>标签中添加属性URIEncoding,令URIEncoding="GBK"。问题解决~
posted @ 2007-01-23 13:39 临江仙 阅读(832) | 评论 (5)编辑 收藏
 
今天尝试着做了一个用JS控制的实现用回车来切换控件的示例,代码如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>用回车实现控件间的切换—示例</title>

<script type="text/javascript" for="document" event="onkeydown">
<!--
  
if(event.keyCode == 13)
     event.keyCode 
= 9;
-->
</script>
</head>
<body>
    姓名:
<input id="input1" type="text"><br>
    年龄:
<input id="input2" type="text"><br/>
    性别:
<select size="1">
            
<option value="1"></option>
            
<option value="2"></option>
            
</select><br>
    籍贯:
<input id="input3" type="text"><br/>
    是否毕业:
<input type="checkbox" name="yes" value="1"/>
    
<input type="checkbox" name="yes" value="1"/><br>
    毕业院校: 
<input id="input4" type="text"><br>
    
<br>
</body>
</html>


posted @ 2006-11-26 16:20 临江仙 阅读(449) | 评论 (0)编辑 收藏
 
以下代码演示如何使用JS实现浮动框效果。不过太简单了,大家可不要砸鸡蛋哦~
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
    
<style type="text/css">
        .Parent 
{
            position
:absolute;
            height
:150px; width:200px;
            top
:0px; left:0px;
            border
:1px solid #123456;
            BACKGROUND-COLOR
: #bbbbbb
        
}
        .Header 
{
            margin
:2px;
              padding
:2px;
              width
:194px;
             color
:white;
             background-color
:navy;
             font-family
:宋体;
              font-size
:12px;
        
}
        .Content 
{
            color
:black;
            font-family
:宋体;
            font-size
:12px;
        
}
    
</style>  

    
<script type="text/javascript">
        
var dx = 0;
        
var dy = 0;
        
var x = 0;
        
var y = 0;
        
var isMouseDown = false;
        
var idNumPre = -1;
        
var root;
        
        
function mouseMove(idNum) {
            
if (isMouseDown) {
                
if (idNumPre != idNum) {
                    root 
= document.getElementById("Parent" + idNum);
                    idNumPre 
= idNum;
                }
                root.style.top 
= event.clientY - dy + "px";    
                root.style.left 
= event.clientX - dx + "px";
                y 
= event.clientY - dy;
                x 
= event.clientX - dx;
            }
        }
        
        
function mouseDown(idNum) {
            dx 
= event.clientX - x;
            dy 
= event.clientY - y;
            isMouseDown 
= true;
        }
        
        
function mouseUp(idNum) {
            isMouseDown 
= false;
        }
    
        
function mouseOut(idNum) {
            isMouseDown 
= false;
        }
    
</script>

</head>
<body>
<div id = "Parent1" class='Parent'>
    
<div id = "header1" class="Header" onmouseup="mouseUp('1');"
        onmousemove
="mouseMove('1');" onmousedown="mouseDown('1');"
        onmouseOut
="mouseOut('1');">浮动框示例
    
</div>
    
<div id = "content1" class="Content">release2006@163.com</div>
</div>
</body>
</html>
posted @ 2006-11-26 00:18 临江仙 阅读(1505) | 评论 (5)编辑 收藏
CALENDER
<2006年11月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

公告

JAVA学习中……

常用链接

留言簿(2)

随笔分类(8)

随笔档案(8)

My Link

搜索

  •  

最新评论

阅读排行榜

评论排行榜


Powered By: 博客园
模板提供沪江博客