js 数组

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-1</title>
</head>
<body>
<h1>通过指定元素创建数组</h1>
<script language="javascript">
    var students = new Array( "Peter", "Tom", "Vicky", "Jet" );    // 通过指定元素创建数组
    for( n in students )
    {
        document.write( students[n] + " " );
    }
</script>
</body>
</html>
toString方法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-2</title>
</head>
<body>
<h1>toString方法的使用</h1>
<script language="javascript">
    var names = ["Peter", "Vicky", "LuWang", "HuaLi"];  // 名字数组
    document.write( names.toString() );                 // 输出所有名字
</script>
</body>
</html>
join方法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-3</title>
</head>
<body>
<h1>join方法的使用</h1>
<script language="javascript">
    var names = ["Peter", "Vicky", "LuWang", "HuaLi"];  // 名字数组
    document.write( names.join( "-" ) );                 // 输出所有名字
</script>
</body>
</html>
push方法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-4</title>
</head>
<body>
<h1>push方法的使用</h1>
<script language="javascript">
var List = new Array();                     // 创建一个空数组作为名单
for( ; ; )
{
    var name = prompt("请输入名字","名字"); // 要求用户输入名字
    if( name==null )                            // 如果用户取消则退出循环
    {
        break;
    }
    List.push( name );                      // 将输入的数据作为数组元素添加到数组
}
var comList = List.join( " " );             // 使用空格将各元素格开,作为字串符输出
document.write( comList );
</script>
</body>
</html>

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-5</title>
</head>
<body>
<script language="javascript">
    var appleBox = new Array();
    appleBox.push( "红苹果1", "红苹果2", "红苹果3", "红苹果4", "红苹果5", "红苹果6" );
    for( ;appleBox.length != 0; )
    {
        var handle = appleBox.pop();
        document.write( "<br>已发:" + handle );
    }
    alert( "苹果已经分光~!" );
</script>
</body>
</html>

 

售票窗口模拟
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-6</title>
</head>
<body>
<h1>售票窗口模拟</h1>
<script language="javascript">
    var queue = new Array();                                                // 购票队列
    function client(name)                                                   // 顾客对象
    {
        this.name = name;                                                   // 顾客名字
        this.ticket = NaN;                                                  // 票号
    }
    queue.push( new client("Lily"), new client("Peter"), 
                new client("Vicky"), new client("Tom"), 
                new client("Jackson") );                                    // 将顾客排队
    tickets = 4;                                                            // 库存票数
    for( ;((queue.length!=0)&&(tickets!=0)) ; )                             // 一直发售直到队伍里没有人或票已经售完
    {
        var current = queue.shift();                                        // 队首已经买到票的人离开队伍
        current.ticket = tickets;
        document.write("<br>已售:" + current.name + ",流水号" + tickets );// 输出已买到票的顾客信息
        tickets --;                                                         // 卖出一张,库存减一
    }
    
    alert( "销售停止,目前队里有" + queue.length + "人,和" + tickets+"张票!" );   // 俏售停止通知
</script>
</body>
</html>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-7</title>
</head>
<body>
<h1>unshift方法的使用</h1>
<script language="javascript">
    var queue = new Array( "A", "B", "C" );                        // 创建一个队列
    document.write( "<br>原数组:" + queue );                    // 输出原数组
    queue.unshift( "D", "E" );                                    // 前端插入两个元素
    document.write( "<br>在前端添加“D”“E”两元素后:" + queue );    // 输出新数组
</script>
</body>
</html>

 

 

concat
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-8</title>
</head>
<body>
<h1>concat的使用示例</h1>
<script language="javascript">
    var queueA = new Array( "顾客1", "顾客2", "顾客3", "顾客4", "顾客5" );  // 窗口A前的队伍A
    var queueB = new Array( "顾客A", "顾客B", "顾客C", "顾客D", "顾客E" );  // 窗口B前的队伍B
    var qa = queueA.join( "-" );                                            // 组合队伍A的成员,使用“-”格开
    var qb = queueB.join( "-" );                                            // 组合队伍B的成员,使用“-”格开
    document.write( "窗口前的两个队伍:" );                                 
    document.write( "<br><li>" + qa );                                      // 输出队伍A的成员                                   
    document.write( "<br><li>" + qb );                                      // 输出队伍B的成员
    queueA = queueA.concat( queueB );                                       // 将队伍B接到队伍A的后面
    qa = queueA.join( "-" );                                                // 组合合并后的队伍,使用“-”格开
    document.write( "<br>将队伍B合并到队伍A:" );                           
    document.write( "<br><li>" + qa );                                      // 输出合并后的队伍成员
</script>
</body>
</html>

 

splice
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-9</title>
</head>
<body>
<h1>splice的使用示例</h1>
<script language="javascript">
    var queueA = new Array();           // 体操队列A
    queueA.push( "学生A", "学生B", "学生C", "学生D", "学生E", "学生F"); // 队员进队
    document.write( "<li>原来的队伍A:<br>" + queueA );                 // 输出队伍A的成员
    var queueB = queueA.splice( 2, 3 ); // 从A队中的第3位学生开始抽出3名学生按顺序组成一个新队
    document.write( "<br><li>调整后的队伍A:<br>" + queueA );           // 输出裁员后的队伍A
    document.write( "<br><li>新建的队伍B:<br>" + queueB );             // 输出从队伍A中切取成员形成的队伍B
    queueA.splice( 1,0, "学生1", "学生2" );                             // 从队伍A的第2个学生处起插入两名学生
    document.write( "<br><li>添加后的队伍A:<br>" + queueA );           // 输出插入学生后的队伍A
</script>
</body>
</html>

 

 

 

slice
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-10</title>
</head>
<body>
<h1>slice方法的作用</h1>
<script language="javascript">
    var queueA = new Array();                                           // 体操队列A
    queueA.push( "学生A", "学生B", "学生C", "学生D", "学生E", "学生F"); // 队员进队
    queueA = queueA.slice( 1, 4 );                                      // 切取第2个到第3个元素作为新数组
    alert( queueA );                                                    // 输出切取出来的数组
</script>
</body>
</html>

 

reverse
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-11</title>
</head>
<body>
<h1>reverse方法的作用</h1>
<script language="javascript">
    var queue = new Array( "", "", "", "" );    // 创建数组
    var newQueue = queue.reverse();                     // 将queue的元素次序反转后形成的新对象内容输出
    document.write( "<li>翻转前:" + queue + "<br><li>翻转后:" + newQueue );
</script>
</body>
</html>

 

 

date.toLocaleString()
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-12</title>
</head>
<body>
<h1>date.toLocaleString()</h1>
<script language="javascript">
    var date = new Date();
    alert( date.toLocaleString() );
</script>
</body>
</html>

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>范例7-13</title>
</head>
<body>
<h1>toLocaleString方法的作用</h1>
<script language="javascript">
    var date = new Date();              // 创建一个日期对象
    alert( date.toLocaleString() );     // 将日期对象作为本地字符串输出
</script>
</body>
</html>

 

Stack(堆栈)对象的测试
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>综合练习7-1</title>
</head>
<body>
<h1>Stack(堆栈)对象的测试</h1>
<script language="javascript">
    function Stack()                    // 定义一个Stack(堆栈)对象的构造函数
    {
        var DateStorage = new Array();  // 创建一个数组作为数据仓库
        this.push = function( obj )     // push方法,压入数据对象
        {
            DateStorage.push( obj );    // 将数据存入仓库
        }
        this.pop = function()           // pop方法,从栈中弹出数据对象
        {
            return DateStorage.pop();   // 数据从仓库取出
        }
    }
    var cartridge_clip = new Stack();   // 测试Stack对象,模拟一个弹夹
    cartridge_clip.push( "子弹1" );     // 压入5颗子弹
    cartridge_clip.push( "子弹2" );
    cartridge_clip.push( "子弹3" );
    cartridge_clip.push( "子弹4" );
    cartridge_clip.push( "子弹5" );
    document.write( "<li>子弹入夹顺序:子弹1 子弹2 子弹3 子弹4 子弹5<br>" );    // 输出子弹入夹顺序
    document.write( "<li>子弹出夹顺序:" );
    for( ; ; )                          // 循环弹出夹中所有子弹
    {
        var cur = cartridge_clip.pop(); // 当前弹出的位于最顶端的子弹
        if( cur == null )               // 如果子弹弹尽时,跳出循环
        {
            break;
        }
        document.write( cur + " " );    // 输出当前子弹名称
    }
</script>
</body>
</html>

 

 

排序

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>练习7-1</title>
</head>
<body>
<h1</h1>
<script language="javascript">
    function mySort( )                              // 不定参数个数的排序函数
    {
        var args = new Array();                     // 使用数组作为参数存储容器
        for( n = 0; n < arguments.length; n++ )     // 提取各实参
        {
           args.push( arguments[n] );               // 将实参压入数组
        }
        for( i = 0; i < args.length; i ++ )         // 逐一比较,从小到大进行排序
        {
            for( j = 0; j < args.length; j ++ ) 
            {
                if( args[i] < args[j] ) 
                {
                    var tmp = args[i];              // 小的数换到大的数前面
                    args[i] = args[j];
                    args[j] = tmp;
                }
            }
        }
        return args;                                // 返回已经排序的数组
    }
    var result = mySort( 5, 1, 6, 3, 2, 9, 7 );     // 对题设中的数字进行排序
    alert( result );                                // 显示结果
</script>
</body>
</html>

 

posted on 2017-08-19 18:55  huodaihao  阅读(193)  评论(0编辑  收藏  举报

导航