Python JavaScript2: 函数

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: Python JavaScript2: 函数

总体内容


1、函数的定义与调用

2、提取行间事件与匿名函数

3、网页换肤

4、变量和函数的域解析

5、函数传参与return关键字


一、函数的定义与调用



  • 1.1、函数:就是重复执行的代码片
  • 1.2、函数定义与执行


<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>函数的基础学习</title>
   <script type="text/javascript">
        <!--函数的定义-->
        function fnAlter() {
             alert("测试弹框")
        }
        function changeColor() {
             var oDiv = document.getElementById("div1")
             oDiv.style.color = 'red'
             oDiv.style.fontSize = '30px'
        }
   </script>
</head>
<body>
   <div id="div1" onclick="fnAlter()">这是一个div元素</div>
   <input type="button" name="" value="改变标签" onclick="changeColor()">
</body>
</html>

提示:函数定义在  <script type="text/javascript"></script> 里面,可以在其他的标签里面设置 onclick="函数名()" 来点击标签调用函数

  • 使用:行间事件


二、提取行间事件与匿名函数



  • 2.1、由于在一中我们把函数的调用写在了 标签(行间)里面,这样做不太好,我们可以把行间事件提取出来,如下


<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>提取行间事件</title>
   <script type="text/javascript">
        window.onload = function () {
             var oBtn = document.getElementById('button1');
             oBtn.onclick = fnChangeDiv;
             function fnChangeDiv() {
                  var oDiv = document.getElementById('div1');
                  oDiv.style.color = 'red';
                  oDiv.style.fontSize = '30px';
             }
        }
   </script>
</head>
<body>
   <div id="div1">这是一个div</div>
   <input type="button" value="改变标签" name="" id="button1">
</body>
</html>
  • 2.2、匿名函数



<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>提取行间事件</title>
   <script type="text/javascript">
       window.onload = function () {
            var oBtn = document.getElementById('button1');
            oBtn.onclick = function() {
                var oDiv = document.getElementById('div1');
                oDiv.style.color = 'red';
                oDiv.style.fontSize = '30px';
            };   
       }
   </script>
</head>
<body>
   <div id="div1">这是一个div</div>
   <input type="button" value="改变标签" name="" id="button1">
</body>
</html>


提示:匿名函数仅仅是把 2.1 中 函数fnChangeDiv名字去掉,直接一步到位 oBtn.onclick = function(){},函数没有了名字也就成了匿名函数

  • 使用的情况:仅仅是做一件事的时候


三、网页换肤



  • 3.1、换肤->仅仅是利用js调用函数更换css,如下


<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>网页换肤</title>
   <link rel="stylesheet" type="text/css" href="css/main1.css" id="link1">
   <script type="text/javascript">
        window.onload = function () {
           var oBtn1 = document.getElementById('button1');
           var oBtn2 = document.getElementById('button2');
           var oLink = document.getElementById('link1');
           oBtn1.onclick = function () {
               oLink.href = 'css/main1.css';
          };
          oBtn2.onclick = function () {
               oLink.href = 'css/main2.css';
          };
       }
</script>
</head>
<body>
    <input type="button" value="皮肤1" name="" id="button1">
    <input type="button" value="皮肤2" name="" id="button2">
</body>
</html>


四、变量和函数的域解析



  • 4.1、JavaScript解析过程分为两个阶段,先是编译阶段,然后执行阶段,在编译阶段会将function定义的函数提前,并且将var定义的变量声明提前,将它赋值为undefined。也就是未定义先使用
  • 4.2、变量的域解析:变量在未定以前如果使用,值会被赋值为undefined


<script type="text/javascript">
    alert(iNum);
    var iNum = 20;
</script>
  • 4.3、函数的域解析:在编译阶段会将function定义的函数提前,函数在定义前或者定义后调用都没事


<script type="text/javascript">
    changeValue()
    function changeValue() {
        alert("hello world!")
    }
</script>


五、函数传参与return关键字



  • 5.1、函数传参
  • <1>、基本的传值


<script type="text/javascript">
      function test(a) {
           alert(a);
      }
      test('hello world!');
</script>
  • <2>、传值改变标签样式


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>函数传参-return关键字</title>
    <script type="text/javascript">
          window.onload = function () {
               function fnChangeStyle(mystyle,val) {
                   var oDiv = document.getElementById('div1');
                   oDiv.style[mystyle] = val;
              }
             fnChangeStyle('color','red')
          }
    </script>
</head>
<body>
    <div id="div1">测试样式</div>
</body>
</html>
  • 5.2、return关键字的作用:返回函数执行的结果、结束函数的运行、阻止默认行为
  • <1>、求和函数,返回结果


<script type="text/javascript">
     function fnAdd(a,b) {
          return a+b;
     }
     alert(fnAdd(3,7));
</script>
  • <2>、结束函数的运行


<script type="text/javascript">
     function fnAdd(a,b) {
          return a+b;
          alert('这里不会再走');
     }
     alert(fnAdd(3,7));
</script>


目录
相关文章
|
1天前
|
开发者 Python
Python入门:8.Python中的函数
### 引言 在编写程序时,函数是一种强大的工具。它们可以将代码逻辑模块化,减少重复代码的编写,并提高程序的可读性和可维护性。无论是初学者还是资深开发者,深入理解函数的使用和设计都是编写高质量代码的基础。本文将从基础概念开始,逐步讲解 Python 中的函数及其高级特性。
Python入门:8.Python中的函数
|
17天前
|
JavaScript 前端开发
JavaWeb JavaScript ③ JS的流程控制和函数
通过本文的详细介绍,您可以深入理解JavaScript的流程控制和函数的使用,进而编写出高效、可维护的代码。
62 32
|
1月前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
16 0
|
1月前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
32 3
|
1月前
|
JSON 监控 安全
深入理解 Python 的 eval() 函数与空全局字典 {}
`eval()` 函数在 Python 中能将字符串解析为代码并执行,但伴随安全风险,尤其在处理不受信任的输入时。传递空全局字典 {} 可限制其访问内置对象,但仍存隐患。建议通过限制函数和变量、使用沙箱环境、避免复杂表达式、验证输入等提高安全性。更推荐使用 `ast.literal_eval()`、自定义解析器或 JSON 解析等替代方案,以确保代码安全性和可靠性。
45 2
|
2月前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
87 8
|
2月前
|
Python
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
64 18
|
2月前
|
Python
Python中的函数
Python中的函数
62 8
|
3月前
|
搜索推荐 Python
利用Python内置函数实现的冒泡排序算法
在上述代码中,`bubble_sort` 函数接受一个列表 `arr` 作为输入。通过两层循环,外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果前一个元素大于后一个元素,就将它们交换位置。
155 67
|
3月前
|
监控 测试技术 数据库
Python中的装饰器:解锁函数增强的魔法####
本文深入探讨了Python语言中一个既强大又灵活的特性——装饰器(Decorator),它以一种优雅的方式实现了函数功能的扩展与增强。不同于传统的代码复用机制,装饰器通过高阶函数的形式,为开发者提供了在不修改原函数源代码的前提下,动态添加新功能的能力。我们将从装饰器的基本概念入手,逐步解析其工作原理,并通过一系列实例展示如何利用装饰器进行日志记录、性能测试、事务处理等常见任务,最终揭示装饰器在提升代码可读性、维护性和功能性方面的独特价值。 ####

热门文章

最新文章

推荐镜像

更多