搜索
首页web前端js教程JavaScript初级教程(第五课续)_基础知识

    在JavaScript中单选框的用法和复选框相似。不同之处在于HTML中的应用。复选框是一种开关。如果一个复选框被选中,你可以再点击后取消选取. 但如果单选框被选中,则只能通过选取另外一个单选框才能取消对该单选框的选取。例:

    在该例中,如果你打算取消对一个单选框的选取,你必须点击另一个单选框。再看下面的程序:

   


        Light off
        Light on
   

    当第一个单选框被选中时,函数offButton() 被调用。函数如下: 

    function offButton()
    {
        var the_box = window.document.form_1.radio_1;

        if (the_box.checked == true)
        {
            window.document.form_1.radio_2.checked = false;
            document.bgColor='black';
            alert("Hey! Turn that back on!");
        }
    }

    这个例子很象前面的复选框例子,主要的区别在于该行: 

    window.document.form_1.radio_2.checked = false;

    该行指令指示JavaScript在该按钮被点击时关闭另外一个按钮。由于另外一个按钮的函数同这个很相似:

    function onButton()
    {
        var the_box = window.document.form_1.radio_2;

        if (the_box.checked == true)
        {
            window.document.form_1.radio_1.checked = false;
            document.bgColor='white';
            alert("Thanks!");
        }
    }



    选单是我们所学的表单选项中最奇特的一种。有两种基本的格式:下列选单和列表选单。以下为例子:

    奇特之处在于这个选单有名称,但其中的各个选项没有名称。例如,在HTML中,第1个选单如下:

 

    注意这个选单的名称是pulldown_1,但各个选项没有名称。所以要调用其中的各个选项则有点困难。

    幸好数组可以帮助我们调用其中的选项。如果你想改变该下列选单中的第2个选项,你可以这样做:

    window.document.form_1.pulldown_1.options[1].text = 'new_text';

    这是因为选单的元素有一个选项属性,而该属性是选单所有选项的集合而成的数组。点击change the selectt然后从下拉选单从下列选单中查看其选项是否已经被改变。现在第2个选项应该是*thau*。

    除了选项属性,选单还有一项属性叫做selectedIndex。一个选项被选择后,selectedIndex属性将变成被选项的数组索引号(序列号)。选择第2个列表选单中的一个选项,然后检查索引号。记住数组中的第1个选项的索引号是0。

    check the index.

    表单的名称是form_1,列表选单的名称是list_1。selectedIndex属性值为window.document.form_1.list_1.selectedIndex。你还可
以将selectedIndex设置如下:

    window.document.form_1.list_1.selectedIndex = 1;

    并高亮度显示第2个选项。

    一旦你得到被选项的索引号,你就可以发现其内容:

    var the_select = window.document.form_1.list_1;

    var the_index = the_select.selectedIndex;

    var the_selected = the_select.options[the_index].text;

    selectedIndex属性很有用,但如果有多个选项同时被选中,会如何呢?

    选单元素的处理器为onChange()。当选单发生变化时,则该处理器被激活。



    尝试这个例子并阅读下面的注释:

    My favorite animal is ...

    注释一个比较复杂的JavaScript程序。首先,我们看看表单本身:

   


       

       
   

    该表单有两个元素:一个下拉选单和一个列表选单。下列选单的处理器调用函数swapOptions()。该函数在首部已经
作了定义,其参数为- 被选的动物种类。

    首部中我首先定义的几个数组:

    var dogs = new Array("poodle","puli","greyhound");

    var fish = new Array("trout", "mackerel", "bass");

    var birds = new Array("robin", "hummingbird", "crow");

    注意这些数组的命名和下拉选单中的命名一致。很快你就会明白为什么。现在我们看看当下拉选单被改变时被调用的函数:

    function swapOptions(the_array_name)
    {
        var numbers_select = window.document.the_form.the_examples;
        var the_array = eval(the_array_name);
        setOptionText(window.document.the_form.the_examples, the_array);
    }

    该函数的定义包括一个参数:the_array_name。如果打开下拉选单并选择"Fish" ,则the_array_name就等同于字符串"Fish"。

    函数主体中第1行包括一个变量用于引用第2个表单元素:列表选单。

    第2行引入一个新概念:eval()。eval()比较奇特,我们留在以后的课程中讲解。第2行命令的这些结果是变量the_array将等同于前面所定义的数组之一。如果the_array_name是"Fish",the_array则等同于Fish数组。如果你想了解这是怎么作的,请学习eval。

    第3行定义另一个函数setOptionText()。setOptionText()用于将the_array赋值给列表选单。以下为该函数内容:

    function setOptionText(the_select, the_array)
    {
        for (loop=0; loop < the_select.options.length; loop++)
        {
            the_select.options[loop].text = the_array[loop];
        }
    }

    该函数有两个参数:对选单元素的引用和一个数组。第1行设立一个for循环,由于循环所有的选单元素。注意选单元素的选项属性是该选单所有选项组成的数组。因为它是一个数组,你可以用长度(length)属性发现数组的元素数目。第1次循环时,循环变量值是0。循环的主体值为:

the_select.options[0].text = the_array[0];

    如果你在下拉选单中选择了"Fish",则the_array[0]就是"trout",所以该行命令将列表选单中的第1个选项改成"trout" 。下一次循环时,循环等于1,并且列表选单中第2个选项则是 "mackerel" 。

    如果你理解了该例子,你对JavaScript的了解就比较深了。 

    初级教程到此结束,随后要发布进阶教程,敬请关注。



声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
在JavaScript中替换字符串字符在JavaScript中替换字符串字符Mar 11, 2025 am 12:07 AM

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

构建您自己的Ajax Web应用程序构建您自己的Ajax Web应用程序Mar 09, 2025 am 12:11 AM

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

10个JQuery Fun and Games插件10个JQuery Fun and Games插件Mar 08, 2025 am 12:42 AM

10款趣味横生的jQuery游戏插件,让您的网站更具吸引力,提升用户粘性!虽然Flash仍然是开发休闲网页游戏的最佳软件,但jQuery也能创造出令人惊喜的效果,虽然无法与纯动作Flash游戏媲美,但在某些情况下,您也能在浏览器中获得意想不到的乐趣。 jQuery井字棋游戏 游戏编程的“Hello world”,现在有了jQuery版本。 源码 jQuery疯狂填词游戏 这是一个填空游戏,由于不知道单词的上下文,可能会产生一些古怪的结果。 源码 jQuery扫雷游戏

jQuery视差教程 - 动画标题背景jQuery视差教程 - 动画标题背景Mar 08, 2025 am 12:39 AM

本教程演示了如何使用jQuery创建迷人的视差背景效果。 我们将构建一个带有分层图像的标题横幅,从而创造出令人惊叹的视觉深度。 更新的插件可与JQuery 1.6.4及更高版本一起使用。 下载

如何创建和发布自己的JavaScript库?如何创建和发布自己的JavaScript库?Mar 18, 2025 pm 03:12 PM

文章讨论了创建,发布和维护JavaScript库,专注于计划,开发,测试,文档和促销策略。

如何在浏览器中优化JavaScript代码以进行性能?如何在浏览器中优化JavaScript代码以进行性能?Mar 18, 2025 pm 03:14 PM

本文讨论了在浏览器中优化JavaScript性能的策略,重点是减少执行时间并最大程度地减少对页面负载速度的影响。

使用jQuery和Ajax自动刷新DIV内容使用jQuery和Ajax自动刷新DIV内容Mar 08, 2025 am 12:58 AM

本文演示了如何使用jQuery和ajax自动每5秒自动刷新DIV的内容。 该示例从RSS提要中获取并显示了最新的博客文章以及最后的刷新时间戳。 加载图像是选择

Matter.js入门:简介Matter.js入门:简介Mar 08, 2025 am 12:53 AM

Matter.js是一个用JavaScript编写的2D刚体物理引擎。此库可以帮助您轻松地在浏览器中模拟2D物理。它提供了许多功能,例如创建刚体并为其分配质量、面积或密度等物理属性的能力。您还可以模拟不同类型的碰撞和力,例如重力摩擦力。 Matter.js支持所有主流浏览器。此外,它也适用于移动设备,因为它可以检测触摸并具有响应能力。所有这些功能都使其值得您投入时间学习如何使用该引擎,因为这样您就可以轻松创建基于物理的2D游戏或模拟。在本教程中,我将介绍此库的基础知识,包括其安装和用法,并提供一

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具