doulaopu2343 2013-07-26 15:26 采纳率: 100%
浏览 108
已采纳

在if语句中使用变量

PHP novice here. I searched for this, but i'm sure i'm not using the right syntax regarding my issue. Apologies then if this is a duplicate:

I have these 3 variables:

$param = get_sub_field('custom_parameter');
$compare = get_sub_field('parameter_compare');
$param_val = get_sub_field('parameter_value');

each one would return this:

$param is 'my_parameter'
$compare is either '==', '<=', or '=>'
$param_val is something like '5' or any value that the user sets

What i have is an editing interface where the user can set their parameter name, set the compare and then add the value. To that they can also add an action that occurs if the parameter matches. I'm using this in conjunction with $_GET.

What i'd like to do is insert each variable from above into my if statement so the comparison is created by the user. However, it keeps giving me an error when i try to do this:

if($_GET[$param] $compare $param_val) {
// do something
}

The error i get is:

Parse error: syntax error, unexpected T_VARIABLE

This of course works just fine:

if($_GET[$param] == $param_val) {
// do something
}

Hopefully i've explained this well enough and any help is greatly appreciated.

Update: Thank you for answering this for me and jumping on it so quickly. Learned a ton here!!

  • 写回答

5条回答 默认 最新

  • dqw70970 2013-07-26 15:31
    关注

    I think I would use a switch statement to avoid any scary eval code.

    Such as:

    switch($compare) {
        case '==':
            if($_GET[$param] == $param_val) {
                // do something
            }
        break;
        case '<=':
            if($_GET[$param] <= $param_val) {
                // do something
            }
        break;
        case '>=':
            if($_GET[$param] <= $param_val) {
                // do something
            }
        break;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?