• 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>
  • 相关阅读:
    学习规划
    一位十年的老司机告诉你什么是编程思想
    React开发
    一个简单的ipfs音乐播放器的实现
    React错误总结(三)
    React错误总结解决方案(二)
    mongoid模糊查询
    Rails accepts_nested_attributes_for表单嵌套的利器
    route_path
    "constantize" and "with_indifferent_access" method
  • 原文地址:https://www.cnblogs.com/huodaihao/p/7397598.html
Copyright © 2020-2023  润新知