(也就是之前传函数名,如今能够直接传匿名函数做为参数了) php
<?php echo preg_replace_callback ( '/-([a-z])/' , function ( $match ) { return strtoupper ( $match [ 1 ]); }, 'hello-world' ); // 输出 helloWorld ?>
闭包函数也能够做为变量的值来使用。PHP 会自动把此种表达式转换成内置类 Closure 的对象实例。
把一个 closure 对象赋值给一个变量的方式与普通变量赋值的语法是同样的,最后也要加上分号: 闭包
<?php $greet = function( $name ) { printf ( "Hello %s\r\n" , $name ); }; $greet ( 'World' ); $greet ( 'PHP' ); ?>
Closure 对象也会从父做用域中继承类属性。这些变量都必须在函数或类的头部声明。从父做用域中继承变量与使用全局变量是不一样的。全局变量存在于一个全局的范围,不管当前在执行的是哪一个函数。而 closure 的父做用域则是声明该 closure 的函数(不必定要是它被调用的函数)。示例以下: 函数
<?php // 一个基本的购物车,包括一些已经添加的商品和每种商品的数量。 // 其中有一个方法用来计算购物车中全部商品的总价格,该方法使 // 用了一个 closure 做为回调函数。 class Cart { const PRICE_BUTTER = 1.00; const PRICE_MILK = 3.00; const PRICE_EGGS = 6.95; protected $products = array(); public function add($product, $quantity) { $this->products[$product] = $quantity; } public function getQuantity($product) { return isset($this->products[$product]) ? $this->products[$product] : FALSE; } public function getTotal($tax) { $total = 0.00; $callback = function ($quantity, $product) use ($tax, &$total) { $pricePerItem = constant(__CLASS__ . "::PRICE_" . strtoupper($product)); $total += ($pricePerItem * $quantity) * ($tax + 1.0); }; array_walk($this->products, $callback); return round($total, 2); } } $my_cart = new Cart; // 往购物车里添加条目 $my_cart->add('butter', 1); $my_cart->add('milk', 3); $my_cart->add('eggs', 6); // 打出出总价格,其中有 5% 的销售税. print $my_cart->getTotal(0.05) . "\n"; // 最后结果是 54.29 ?>
这里要注意理解当使用 array_walk($this->products, $callback) 调用 function($quantity, $product) use ($tax, &$total).
这里 $quantity, $product 分别是 $this->products 的key和value,属于匿名函数接收到参数。
而 use 后面跟的是匿名函数外部做用域的变量。 this