如何用三元运算符编写这些"if.else"条件语句



我想用三元运算符编写这些if..else语句:

if((($request->city)=="98")&&($cartPrice >= 300000)&&($request->province)=="8")){
"ort_free_delivery" => 'City sending free delivery'
}elseif((($request->city)!="98")&&($cartPrice >=300000)&&($request->province)!="8")){
"ort_free_delivery" => 'Country sending free delivery'
}else{
"ort_free_delivery" => '',
}

这是我的尝试:

( ( ($request->city)=="98" ) ? ($cartPrice>=300000) ? ( ( ($request->province)=="8" ) ? "ort_free_delivery" == "City sending free delivery" ) ); 
( ( ($request->city)!="98" ) ? ($cartPrice>=300000) ? ( ( ($request->province)!="8" ) ? "ort_free_delivery" == "Country sending free delivery" : "ort_free_delivery" == "" ) ); 

但这是错误的,因为有两行三元运算符,我需要在一行中满足这个条件(因为我在Laravel中插入一些带有DB类的数据(:

DB::table('order_detail')->insert([
"ort_ord_id" => $orderId,
"ort_amount" => $value->price,
"ort_total" => $value->discounted * $value->quantity,
"ort_discount" => ($value->price * $value->quantity) - $value->discounted * $value->quantity,
"ort_type" => "product",
"ort_number" => $value->quantity,
"ort_reference_id" => $value->id,
( ( ($request->city)=="98" ) ? ($cartPrice>=300000) ? ( ( ($request->province)=="8" ) ? "ort_free_delivery" == "City sending free delivery" ) )
( ( ($request->city)!="98" ) ? ($cartPrice>=300000) ? ( ( ($request->province)!="8" ) ? "ort_free_delivery" == "Country sending free delivery" : "ort_free_delivery" == "" ) )
"created_at" => now(),
"updated_at" => now()
]);

所以我的问题是,如何在一行中添加带有三元运算符的条件语句?

一个选项是构建数组,然后插入

$data=[
"ort_ord_id" => $orderId,
"ort_amount" => $value->price,
"ort_total" => $value->discounted * $value->quantity,
"ort_discount" => ($value->price * $value->quantity) - $value->discounted * $value->quantity,
"ort_type" => "product",
"ort_number" => $value->quantity,
"ort_reference_id" => $value->id,
"created_at" => now(),
"updated_at" => now()
];  

对于条件数据

if($request->city==98&&$cartPrice >= 300000&&$request->province==8){
$data["ort_free_delivery"] = 'City sending free delivery';
}elseif($request->city!=98&&$cartPrice >=300000&&$request->province!=8){
$data["ort_free_delivery"] = 'Country sending free delivery';
}else{
$data["ort_free_delivery"] = '';
}

然后查询

DB::table('order_detail')->insert($data);

DB::table('order_detail')->insert([
"ort_ord_id" => $orderId,
"ort_amount" => $value->price,
"ort_total" => $value->discounted * $value->quantity,
"ort_discount" => ($value->price * $value->quantity) - $value->discounted * $value->quantity,
"ort_type" => "product",
"ort_number" => $value->quantity,
"ort_reference_id" => $value->id,
"ort_free_delivery" =>($request->city==98&&$cartPrice >= 300000&&$request->province==8)?'City sending free delivery':
(($request->city!=98&&$cartPrice >=300000&&$request->province!=8)?'Country sending free delivery':null),
"created_at" => now(),
"updated_at" => now()
]);

你可以试试这个。这个想法是用第二个三进制替换第一个:之后的语句。只有当第一个条件为false时,才会对第二个三进制进行求值。

DB::table('order_detail')->insert([
"ort_ord_id" => $orderId,
"ort_amount" => $value->price,
"ort_total" => $value->discounted * $value->quantity,
"ort_discount" => ($value->price * $value->quantity) - $value->discounted * $value->quantity,
"ort_type" => "product",
"ort_number" => $value->quantity,
"ort_reference_id" => $value->id,
"ort_free_delivery" => ( ( ($request->city)=="98" ) &&  ($cartPrice>=300000) && ( ($request->province)=="8" ) ) ? "City sending free delivery" : ( ( ($request->city)!="98" ) && ($cartPrice>=300000) && ( ($request->province)!="8" ) ) ? "Country sending free delivery" : "" ) ),
"created_at" => now(),
"updated_at" => now()
]);

使用var_dump进行测试,而不是您所拥有的,这就是我所想到的:

(((($request->city=="98")&&($cartPrice>=300000)&&($request->province=="8"))?var_dump('1'):((($request->city!="98")&&($cartPrice>=300000)&&($request->province=="8"))?var_dump('2'):var_dump('3'))))

以更可读的方式:

(
(
(
($request->city == "98") && 
($cartPrice >= 300000) && 
($request->province == "8")
)
? var_dump('1') 
: (
(
($request->city != "98") && 
($cartPrice >= 300000) && 
($request->province == "8") 
)
? var_dump('2')
: var_dump('3')
)
)
)
"ort_free_delivery" => ($cartPrice >= 300000 ? ( $request->city=="98" && $request->province=="8" ? 'City sending free delivery' : 'Country sending free delivery' ) : '')

人工读取代码:

如果cartPrice低于300000总是">

否则,如果两个城市同时为98,而省同时为8(and(。。。

是";城市发送">

其他

是";发送国家/地区">

因为

主要的区别规则似乎是城市=98和省份=8都必须为True才能是"城市发送"。。。

所以所有其他情况都是"国家发送"。。。

当运费>=300000

最新更新