zoukankan      html  css  js  c++  java
  • 浅谈php函数的参数的设定规则

      函数可以设定参数,也可以留空不进行设定。

    1.当php函数设定形参,但是引用时实参不给,情况如下:

     1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     2 <html xmlns="http://www.w3.org/1999/xhtml">
     3 <head>
     4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     5 <title>php函数测试</title>
     6 </head>
     7 
     8 <body>
     9 <?php 
    10 /*********************
    11 *Author:瞎猫碰上死老虎***
    12 *Date:2/6/2015********
    13 *********************/
    14 
    15 function asd($a,$b,$c){
    16     echo $a+$b+$c;
    17 }
    18 
    19 asd();
    20 
    21 
    22 ?>
    23 </body>
    24 </html>

    结果为:

     1 Warning: Missing argument 1 for asd(), called in F:phpfindWWWceshi.php on line 19 and defined in F:phpfindWWWceshi.php on line 15
     2 
     3 Warning: Missing argument 2 for asd(), called in F:phpfindWWWceshi.php on line 19 and defined in F:phpfindWWWceshi.php on line 15
     4 
     5 Warning: Missing argument 3 for asd(), called in F:phpfindWWWceshi.php on line 19 and defined in F:phpfindWWWceshi.php on line 15
     6 
     7 Notice: Undefined variable: b in F:phpfindWWWceshi.php on line 16
     8 
     9 Notice: Undefined variable: a in F:phpfindWWWceshi.php on line 16
    10 
    11 Notice: Undefined variable: c in F:phpfindWWWceshi.php on line 16
    12 0

    结论:会报错,但是也能显示出结果来。为0。

    2.函数有形参,引用时,第一个实参什么都没有用逗号隔开,后面给实参。这个时候语法错误。这种写法在PHP是不支持的。如果你想这样,可以给NULL。示例如下:

     1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     2 <html xmlns="http://www.w3.org/1999/xhtml">
     3 <head>
     4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     5 <title>php函数测试</title>
     6 </head>
     7 
     8 <body>
     9 <?php 
    10 /*********************
    11 *Author:瞎猫碰上死老虎***
    12 *Date:2/6/2015********
    13 *********************/
    14 
    15 function asd($a,$b,$c){
    16     echo $a+$b+$c;
    17 }
    18 
    19 asd(NULL,3,7);
    20 
    21 
    22 ?>
    23 </body>
    24 </html>

    结果为:

    1 10

    3.现在来进行测试形参设置了默认参数的情况,情况如下:

     1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     2 <html xmlns="http://www.w3.org/1999/xhtml">
     3 <head>
     4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     5 <title>php函数测试</title>
     6 </head>
     7 
     8 <body>
     9 <?php 
    10 /*********************
    11 *Author:瞎猫碰上死老虎***
    12 *Date:2/6/2015********
    13 *********************/
    14 
    15 function asd($a,$b=2,$c=5){
    16     echo $a+$b+$c;
    17 }
    18 
    19 asd(3,7);
    20 
    21 
    22 ?>
    23 </body>
    24 </html>

    结果为:

    1 15

    结论:如果有默认形参,实参可以不给。实参的顺序是按照形参的顺序来的。如果函数参数中,参数的后面有默认形参,那么实参可以不给出对应的参数。函数将按默认形参代入计算。

    4.再来看一种情况。这个时候三个参数中,就中间设置了默认形参。如果给了两个实参,这个情况是怎么样的呢。

     1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     2 <html xmlns="http://www.w3.org/1999/xhtml">
     3 <head>
     4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     5 <title>php函数测试</title>
     6 </head>
     7 
     8 <body>
     9 <?php 
    10 /*********************
    11 *Author:瞎猫碰上死老虎***
    12 *Date:2/6/2015********
    13 *********************/
    14 
    15 function asd($a,$b=2,$c){
    16     echo $a+$b+$c;
    17 }
    18 
    19 asd(8,9);
    20 
    21 
    22 ?>
    23 </body>
    24 </html>

    结果为:

    1 Warning: Missing argument 3 for asd(), called in F:phpfindWWWceshi.php on line 19 and defined in F:phpfindWWWceshi.php on line 15
    2 
    3 Notice: Undefined variable: c in F:phpfindWWWceshi.php on line 16
    4 17

    结论:引用函数的时候,实参的顺序跟形参一一对应。如果无默认形参,不给相应的实参则会报错。当有默认形参在函数的参数组后面,这个时候省略是不会出现错误的,函数将按照默认形参参与运算。

  • 相关阅读:
    react脚手架搭建及配置
    mac使用技巧
    nginx配置
    vue常见前端UI库
    自定义指令
    代码缩进修改
    webpack学习入门
    webpack使用extract-text-webpack-plugin打包时提示错误
    webpack未成功全局安装
    基于jQuery的AJAX实现三级联动菜单
  • 原文地址:https://www.cnblogs.com/soongkun/p/4277544.html
Copyright © 2011-2022 走看看