js中传参的实例 多组图片的指定切换与商品价格的计算

2024-03-20 12:08

本文主要是介绍js中传参的实例 多组图片的指定切换与商品价格的计算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

                                             js中函数传递参数的实例

 一、在js中函数的传递参数可以很好的实现代码的重用

         代码的重用需要注意以下几点

      1、尽量保持HTML代码结构一致,可以通过父级选取子元素
      2、把核心主要程序实现,并用函数包起来
      3、把每组里不同的值找出来,并用函数传参实现
二、利用js中函数传参实现多组图片的指定切换效果
      代码如下:
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>js的图片指定切换效果</title>
        <style>
            h1{ height:30px; width:300px; border:2px solid pink; font-size:25px; text-                             align:center; line-height:30px; margin:40px auto;}
            .box{ height:350px; width:500px; border:2px solid yellow; position:relative;                            margin-right:100px; margin-left:50px; float:left;}
            .box img{ height:350px; width:500px;}
            ul{ padding:0; margin:0; position:absolute; top:0; right:-80px;}
            li{ height:50px; width:50px; background:pink; border:2px solid #CCC; margin-                   bottom:5px; list-style:none;}
            .box .active{ background:yellow;}
            .box p,span{ height:30px; width:500px; background:#CCC; font-size:20px;                                       text-align:center; line-height:30px; color:#FFF; position:absolute;                                 left:0; margin:0;}
            p{ bottom:0;}
            span{ top:0;}
        </style>
        <script>
            window.onload = function(){
                fnTab1('pic1',['imgs/z.1.jpg','imgs/z.2.jpg','imgs/z.3.jpg','imgs/z.4.jpg'],['眺望                             远方','在海边嬉戏','爱心世界','美丽花环'],'onclick');
                           //传入id值,数组,以及事件
                fnTab1('pic2',['imgs/z.1.jpg','imgs/z.2.jpg','imgs/z.3.jpg','imgs/z.4.jpg'],['眺望                              远方','在海边嬉戏','爱心世界','美丽花环'],'onmousemove');
                // 可以传递不同的值,值不同时,得到的效果也是不同的

                function fnTab1( id,arrUrl,arrText,evt ){
                    var oDiv = document.getElementById(id);
                    var oImg = oDiv.getElementsByTagName('img')[0];
                    var oSpan = oDiv.getElementsByTagName('span')[0];
                    var oP = oDiv.getElementsByTagName('p')[0];
                    var oUl = oDiv.getElementsByTagName('ul')[0];
                    var aLi = oDiv.getElementsByTagName('li');
                    var num = 0;

                    for( var i=0;i<arrUrl.length;i++){
                        oUl.innerHTML += '<li></li>';
                    }

                     //初始化
                    function fnTab2(){
                        oImg.src = arrUrl[num];
                        oSpan.innerHTML = 1 + num +'/' +arrUrl.length;
                        oP.innerHTML = arrText[num];
                        for( var i=0;i<aLi.length;i++){
                            aLi[i].className = '';
                        }
                        aLi[num].className = 'active';
                        }
                        fnTab2();

                        for( var i=0;i<aLi.length;i++){
                             aLi[i].index = i;
                             aLi[i][evt] = function(){
                           // 在js中 如果后面的值是固定的可以用".",如果后面的值是变化的需                                  要用"[]",在js中"[]"可以代替任意位置的".",之前有提过
                               num = this.index;
                               fnTab2();
                            }
                        }
                   }
                
              }
        </script>
    </head>
    <body>
        <h1>js的图片指定切换效果</h1>
        <div id="pic1" class="box">
            <img src="" alt="" />
            <span>数量正在计算中...</span>
            <p>文字正在加载中...</p>
            <ul></ul>
        </div>

        <div id="pic2" class="box">
            <img src="" alt="" />
            <span>数量正在计算中...</span>
            <p>文字正在加载中...</p>
            <ul></ul>
        </div>
    </body>
</html>

三、 利用js中函数传参实现商品价格的计算效果
      代码如下:
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>js的商品价格计算</title>
        <style>
            ul{ padding:0; margin:0;}
            li{ list-style:none; margin-bottom:20px;}
            input{ height:40px; width:40px;}
            strong{ font-size:20px;}
            span{ font-size:20px; color:red;}
        </style>
        <script>
            window.onload = function(){
                var oUl = document.getElementById('list');
                var aLi = oUl.getElementsByTagName('li');
                
                for( var i=0;i<aLi.length;i++){
                    fn1(aLi[i]);
                } // 传递的是数组,内容相同,用for循环传入

                function fn1( oLi ){
                    var aInp = oLi.getElementsByTagName('input');
                    var oStrong = oLi.getElementsByTagName('strong')[0];
                    var oB = oLi.getElementsByTagName('b')[0];
                    var oSpan = oLi.getElementsByTagName('span')[0];
                    var n1 = Number(oStrong.innerHTML); //  '0' 得到的是字符串
                    var n2 = parseFloat(oB.innerHTML);
                    // 在js中用innerHTML获得的HTML内的内容全部是字符串型

                    aInp[0].onclick = function(){
                        n1 --;
                        if( n1<0 ){
                            n1 = 0;
                        }
                        oStrong.innerHTML = n1;
                        oSpan.innerHTML = n1*n2 + '元';
                    // 转换时转换为数字型,得到值时,应加上字符串型
                    }
                    aInp[1].onclick = function(){
                        n1 ++;
                        oStrong.innerHTML = n1;
                        oSpan.innerHTML = n1*n2 + '元';
                     // 转换时转换为数字型,得到值时,应加上字符串型
                    }
                }
            }
        </script>
    </head>
    <body>
        <h1>js的商品价格计算</h1>
        <ul id="list">
            <li>
                <input type="button" value="-" />
                <strong>0</strong>
                <input type="button" value="+" />
                单价:<b>12.5元</b>
                小计:<span>0元</span>
            </li>
            <li>
                <input type="button" value="-" />
                <strong>0</strong>
                <input type="button" value="+" />
                单价:<b>10.5元</b>
                小计:<span>0元</span>
            </li>
            <li>
                <input type="button" value="-" />
                <strong>0</strong>
                <input type="button" value="+" />
                单价:<b>8.5元</b>
                小计:<span>0元</span>
            </li>
            <li>
                <input type="button" value="-" />
                <strong>0</strong>
                <input type="button" value="+" />
                单价:<b>8元</b>
                小计:<span>0元</span>
            </li>
        </ul>
    </body>
</html>
注意:在此篇文章中,虽然是js传参的实例,但里面有很多我们在实现效果时需要注意              的知识点,用红色标注的一定要多加注意,颜色越深越应该更注意,黄色为举例            的名称。

这篇关于js中传参的实例 多组图片的指定切换与商品价格的计算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/829407

相关文章

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

springboot security验证码的登录实例

《springbootsecurity验证码的登录实例》:本文主要介绍springbootsecurity验证码的登录实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录前言代码示例引入依赖定义验证码生成器定义获取验证码及认证接口测试获取验证码登录总结前言在spring

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的