使用lambda函数减少函数代码

时间:2013-08-14 17:35:50

标签: php optimization lambda

我有一个函数可以减少(优化)它具有的代码行数量。这个函数有一些重复的片段。

可以使用lambda函数减少此代码吗?

这是我的功能代码:

static function get_all_category_with_widgets( $status = 'all' ) {
            $all_categories = SB_Central::get_categories();
            $all_widgets    = SB_Settings::get_sb_widgets(); // Get all widgets from options variable.

            foreach ( $all_categories as $category_key => $category_value ) {
                foreach ( $all_widgets as $widget_value ) {
                    // Create one widget
                    $widget = array_merge($widget_value['widget'], array ( 'id' => $widget_value['id'], 'status' => $widget_value['status']));

                    // In this case save active and disable.
                    if ( $status == 'active_and_disable' && ( $widget_value['status'] == 'active' || $widget_value['status'] == 'disable' )) {
                        if ( $category_value[ 'category_title' ] == $widget_value[ 'category' ][ 'title' ] ) {
                            $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
                        }
                    } elseif ( $status == 'active' && $widget_value['status'] == 'active' ) {
                        if ( $category_value[ 'category_title' ] == $widget_value[ 'category' ][ 'title' ] ) {
                            $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
                        }
                    } elseif ( $status == 'disable' && $widget_value['status'] == 'disable' ) {
                        if ( $category_value[ 'category_title' ] == $widget_value[ 'category' ][ 'title' ] ) {
                            $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
                        }
                    } elseif ( $status == 'deleted' && $widget_value['status'] == 'deleted' ) {
                        if ( $category_value[ 'category_title' ] == $widget_value[ 'category' ][ 'title' ] ) {
                            $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
                        }
                    } elseif ( $status == 'all' ) {
                        if ( $category_value[ 'category_title' ] == $widget_value[ 'category' ][ 'title' ] ) {
                            $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
                        }
                    }
                }
            }

            return $all_categories;
        }

这是我总是重复的代码:

if ( $category_value[ 'category_title' ] == $widget_value[ 'category' ][ 'title' ] ) {
                            $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
                        } 

如果您知道减少此代码的更好方法,欢迎使用。

1 个答案:

答案 0 :(得分:1)

您可以使用以下更多的terser表示替换if / elseif / elseif ....块

if ( $category_value[ 'category_title' ] == $widget_value[ 'category' ][ 'title' ] ) {
    switch ($status){
        case "active_and_disable":
            // set if widget statis is active or disable
            if( $widget_value['status'] == 'active' || $widget_value['status'] == 'disable' ){
                $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
            }
            break;
        case "all":
            // always set
            $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
            break;
        default:
            // set when status == widget status
            if ($status == $widget_value['status']){
                $all_categories[ $category_key ][ 'widgets' ][ ] = $widget; // Save widget
            }
            break;
    }
}