PHP函数参数传递方法的具体改进技巧分享_PHP教程
当我们在写本人在经历了多次重复操作之后决定改进一下传统PHP函数参数传递方法,使用数组作为参数,请看下面的例子.
先看一个传统的自定义函数
<ol class="dp-xml"> <li class="alt"><span><span>/** </span></span></li> <li class=""><span>* @Purpose: 插入文本域 </span></li> <li class="alt"><span>* @Method Name: addInput() </span></li> <li class=""><span>* @Parameter: str $title 表单项标题 </span></li> <li class="alt"><span>* @Parameter: str $name 元素名称 </span></li> <li class=""><span>* @Parameter: str $value 默认值 </span></li> <li class="alt"><span>* @Parameter: str $type 类型,默认为text,可选password </span></li> <li class=""><span>* @Parameter: str $maxlength 最长输入 </span></li> <li class="alt"><span>* @Parameter: str $readonly 只读 </span></li> <li class=""><span>* @Parameter: str $required 是否必填,默认为false,true为必填 </span></li> <li class="alt"><span>* @Parameter: str $check 表单验证function(js)名称 </span></li> <li class=""><span>* @Parameter: str $id 元素id,无特殊需要时省略 </span></li> <li class="alt"><span>* @Parameter: int $width 元素宽度,单位:象素 </span></li> <li class=""><span>* @Parameter: str $tip 元素提示信息 </span></li> <li class="alt"><span>* @Return: </span></li> <li class=""><span>*/ </span></li> <li class="alt"> <span>function addInput($title,$name,$</span><span class="attribute"><font color="#ff0000">value</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">""</font></span><span>,$</span><span class="attribute"><font color="#ff0000">type</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">"text"</font></span><span>,$</span><span class="attribute"><font color="#ff0000">maxlength</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">"255"</font></span><span>,<br>$readonly,$</span><span class="attribute"><font color="#ff0000">required</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">"false"</font></span><span>,$check,$id,$width,$tip) </span> </li> <li class=""><span>{ </span></li> <li class="alt"> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= </span><span class="attribute-value"><font color="#0000ff">"<li>n"</li></font></span><span>; </span> </li> <li class=""> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= </span><span class="attribute-value"><font color="#0000ff">"<label>"</label></font></span><span>.$title.":</span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">label</span><span class="tag">></span></font></strong><span>n"; </span> </li> <li class="alt"> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= "</span><strong><font color="#006699"><span class="tag"><span class="tag-name">input</span></span></font></strong><span> name="</span><span class="attribute-value"><font color="#0000ff">".$name."</font></span><span>" </span><span class="attribute"><font color="#ff0000">value</font></span><span>="".$value."" </span><span class="attribute"><font color="#ff0000">type</font></span><span>=""<br>.$type."" </span><span class="attribute"><font color="#ff0000">maxlength</font></span><span>="".$maxlength."" </span><span class="attribute"><font color="#ff0000">required</font></span><span>="".$required."" </span><span class="attribute"><font color="#ff0000">check</font></span><span>=""<br>.$check."" </span><span class="attribute"><font color="#ff0000">id</font></span><span>="".$id."" </span><span class="attribute"><font color="#ff0000">class</font></span><span>="input" ".$readonly." </span><span class="attribute"><font color="#ff0000">style</font></span><span>="width:".$width.<br>"px;" </span><span class="attribute"><font color="#ff0000">showName</font></span><span>="".$title."" </span><span class="tag"><strong><font color="#006699">/></font></strong></span><span> "; </span> </li> <li class=""> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= "</span><strong><font color="#006699"><span class="tag"><span class="tag-name">span</span></span></font></strong><span> class="</span><span class="attribute-value"><font color="#0000ff">tip</font></span><span>"</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>".$tip."</span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">span</span><span class="tag">></span></font></strong><span>n"; </span> </li> <li class="alt"> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= </span><span class="attribute-value"><font color="#0000ff">"</font></span> </li>n"<span>; </span><li class=""><span>} </span></li> </ol>
这是我写的表单类中一个插入文本框的函数.
PHP函数参数传递方法的调用方法为
<ol class="dp-xml"><li class="alt"><span><span>$form-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>addInput("编码","field0","","text",3,""); </span></span></li></ol>
在开始的时候只预留了$title,$name,$value,$type,$maxlength,$readonly等参数,经过一段时间的使用,发现这些基本参数无法满足需求,文本框需要有js验证,需要定义CSS样式,需要增加提示信息等...
增加了$required,$check,$id,$width,$tip等参数之后发现以前所有调用此函数的地方都需要修改,增加了很多工作量.
PHP函数参数传递方法的调用方法变成
<ol class="dp-xml"><li class="alt"><span><span>$form-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>addInput("编码","field0","","text",3,"","true",""<br>,"",100,"提示:编号为必填项,只能填写3位"); </span></span></li></ol>
如果使用这个函数的地方很多的话一个一个改确实需要很长时间.
下面是我改进之后的函数
<ol class="dp-xml"> <li class="alt"><span><span>function addInput($a) </span></span></li> <li class=""><span>{ </span></li> <li class="alt"><span> if(is_array($a)) </span></li> <li class=""><span> { </span></li> <li class="alt"> <span> $</span><span class="attribute"><font color="#ff0000">title</font></span><span> = $a['title']; </span> </li> <li class=""> <span> $</span><span class="attribute"><font color="#ff0000">name</font></span><span> = $a['name']; </span> </li> <li class="alt"> <span> $</span><span class="attribute"><font color="#ff0000">value</font></span><span> = $a['value'] ? $a['value'] : ""; </span> </li> <li class=""> <span> $</span><span class="attribute"><font color="#ff0000">type</font></span><span> = $a['type'] ? $a['type'] : "text"; </span> </li> <li class="alt"> <span> $</span><span class="attribute"><font color="#ff0000">maxlength</font></span><span> = $a['maxlength'] ? $a['maxlength'] : "255"; </span> </li> <li class=""> <span> $</span><span class="attribute"><font color="#ff0000">readonly</font></span><span> = $a['readonly'] ? $a['readonly'] : ""; </span> </li> <li class="alt"> <span> $</span><span class="attribute"><font color="#ff0000">required</font></span><span> = $a['required'] ? $a['required'] : "false"; </span> </li> <li class=""> <span> $</span><span class="attribute"><font color="#ff0000">check</font></span><span> = $a['check']; </span> </li> <li class="alt"> <span> $</span><span class="attribute"><font color="#ff0000">id</font></span><span> = $a['id']; </span> </li> <li class=""> <span> $</span><span class="attribute"><font color="#ff0000">width</font></span><span> = $a['width']; </span> </li> <li class="alt"> <span> $</span><span class="attribute"><font color="#ff0000">tip</font></span><span> = $a['tip']; </span> </li> <li class=""><span> } </span></li> <li class="alt"> <span> $title,$name,$</span><span class="attribute"><font color="#ff0000">value</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">""</font></span><span>,$</span><span class="attribute"><font color="#ff0000">type</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">"text"</font></span><span>,$</span><span class="attribute"><font color="#ff0000">maxlength</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">"255"</font></span><span>,$readonly,$</span><span class="attribute"><font color="#ff0000">required</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">"false"</font></span><span>,$check,$id,$width,$tip </span> </li> <li class=""> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= </span><span class="attribute-value"><font color="#0000ff">"<li>n"</li></font></span><span>; </span> </li> <li class="alt"> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= </span><span class="attribute-value"><font color="#0000ff">"<label>"</label></font></span><span>.$title.":</span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">label</span><span class="tag">></span></font></strong><span>n"; </span> </li> <li class=""> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= "</span><strong><font color="#006699"><span class="tag"><span class="tag-name">input</span></span></font></strong><span> name="</span><span class="attribute-value"><font color="#0000ff">".$name."</font></span><span>" </span><span class="attribute"><font color="#ff0000">value</font></span><span>="".$value."" </span><span class="attribute"><font color="#ff0000">type</font></span><span>="".$type."" </span><span class="attribute"><font color="#ff0000">maxlength</font></span><span>="".$maxlength."" </span><span class="attribute"><font color="#ff0000">required</font></span><span>="".$required."" </span><span class="attribute"><font color="#ff0000">check</font></span><span>="".$check."" </span><span class="attribute"><font color="#ff0000">id</font></span><span>="".$id."" </span><span class="attribute"><font color="#ff0000">class</font></span><span>="input" ".$readonly." </span><span class="attribute"><font color="#ff0000">style</font></span><span>="width:".$width."px;" </span><span class="attribute"><font color="#ff0000">showName</font></span><span>="".$title."" </span><span class="tag"><strong><font color="#006699">/></font></strong></span><span> "; </span> </li> <li class="alt"> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= "</span><strong><font color="#006699"><span class="tag"><span class="tag-name">span</span></span></font></strong><span> class="</span><span class="attribute-value"><font color="#0000ff">tip</font></span><span>"</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>".$tip."</span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">span</span><span class="tag">></span></font></strong><span>n"; </span> </li> <li class=""> <span> $this-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>form </span><span class="attribute"><font color="#ff0000">.</font></span><span>= </span><span class="attribute-value"><font color="#0000ff">"</font></span> </li>n"<span>; </span><li class="alt"><span>} </span></li> </ol>
调用方法变为
<ol class="dp-xml"> <li class="alt"><span><span>$form-</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>addInput( </span></span></li> <li class=""><span> array( </span></li> <li class="alt"><span> 'title' = "编码", </span></li> <li class=""><span> 'name' = "field0", </span></li> <li class="alt"><span> 'maxlength' = 3, </span></li> <li class=""><span> 'required' = "true", </span></li> <li class="alt"><span> 'width' = 100, </span></li> <li class=""><span> 'tip' = "提示:编号为必填项,只能填写3位", </span></li> <li class="alt"><span> ) </span></li> <li class=""><span>); </span></li> </ol>
经过前后PHP函数参数传递方法的对比可以发现:
传统的函数在需要扩展的时候改动量大,使用的时候必须按参数的顺序写,很容易出错.
改进后的函数扩展的时候可以随时增加新参数,只需要在调用时增加对应的数组键值,每个参数都一目了然,无需考虑顺序,代码可读性增强.
不过PHP函数参数传递方法的改进还是有缺点的,代码量增大了,需要程序员多写很多键值,还有就是函数中判断语句和三元运算语句可能会影响效率.

PHP dan Python masing -masing mempunyai kelebihan sendiri, dan pilihannya harus berdasarkan keperluan projek. 1.Php sesuai untuk pembangunan web, dengan sintaks mudah dan kecekapan pelaksanaan yang tinggi. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan yang kaya.

PHP tidak mati, tetapi sentiasa menyesuaikan diri dan berkembang. 1) PHP telah menjalani beberapa lelaran versi sejak tahun 1994 untuk menyesuaikan diri dengan trend teknologi baru. 2) Ia kini digunakan secara meluas dalam e-dagang, sistem pengurusan kandungan dan bidang lain. 3) Php8 memperkenalkan pengkompil JIT dan fungsi lain untuk meningkatkan prestasi dan pemodenan. 4) Gunakan OPCACHE dan ikut piawaian PSR-12 untuk mengoptimumkan prestasi dan kualiti kod.

Masa depan PHP akan dicapai dengan menyesuaikan diri dengan trend teknologi baru dan memperkenalkan ciri -ciri inovatif: 1) menyesuaikan diri dengan pengkomputeran awan, kontena dan seni bina microservice, menyokong Docker dan Kubernetes; 2) memperkenalkan pengkompil JIT dan jenis penghitungan untuk meningkatkan prestasi dan kecekapan pemprosesan data; 3) Berterusan mengoptimumkan prestasi dan mempromosikan amalan terbaik.

Dalam PHP, sifat sesuai untuk situasi di mana penggunaan semula kaedah diperlukan tetapi tidak sesuai untuk warisan. 1) Ciri membolehkan kaedah multiplexing dalam kelas untuk mengelakkan pelbagai kerumitan warisan. 2) Apabila menggunakan sifat, anda perlu memberi perhatian kepada konflik kaedah, yang dapat diselesaikan melalui alternatif dan sebagai kata kunci. 3) Tua yang berlebihan harus dielakkan dan tanggungjawab tunggalnya harus dikekalkan untuk mengoptimumkan prestasi dan meningkatkan pemeliharaan kod.

Kontena Suntikan Ketergantungan (DIC) adalah alat yang menguruskan dan menyediakan kebergantungan objek untuk digunakan dalam projek PHP. Manfaat utama DIC termasuk: 1. Decoupling, membuat komponen bebas, dan kod itu mudah dikekalkan dan diuji; 2. Fleksibiliti, mudah untuk menggantikan atau mengubah suai kebergantungan; 3. Keseluruhan, mudah untuk menyuntik objek mengejek untuk ujian unit.

SplfixedArray adalah pelbagai saiz tetap dalam PHP, sesuai untuk senario di mana prestasi tinggi dan penggunaan memori yang rendah diperlukan. 1) Ia perlu menentukan saiz apabila membuat untuk mengelakkan overhead yang disebabkan oleh pelarasan dinamik. 2) Berdasarkan pelbagai bahasa C, secara langsung mengendalikan memori dan kelajuan akses cepat. 3) Sesuai untuk pemprosesan data berskala besar dan persekitaran sensitif memori, tetapi ia perlu digunakan dengan berhati-hati kerana saiznya tetap.

PHP mengendalikan fail muat naik melalui pembolehubah fail $ \ _. Kaedah untuk memastikan keselamatan termasuk: 1. Semak kesilapan muat naik, 2. Sahkan jenis dan saiz fail, 3. Mencegah penindasan fail, 4. Pindahkan fail ke lokasi storan tetap.

Dalam JavaScript, anda boleh menggunakan NullcoalescingOperator (??) dan NullcoalescingAssignmentOperator (?? =). 1.? Menerapkan semula operan pertama yang tidak berselisih atau tidak ditentukan. 2.?? Pengendali ini memudahkan logik kod, meningkatkan kebolehbacaan dan prestasi.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular