寫法
// 單行
${!${''} = 代碼}
// 多行
${!${''} =
代碼
}
個人認為這種寫法實際上還是通過解析變量實作的。= 左邊是一個特殊名稱的變量,= 右邊隻要符合指派變量的代碼塊均可以在字元串中解析。
示例
以下代碼僅供學習交流,實際工作中不建議用這種寫法。
一、
$fruits = implode('、', ['apple', 'banana']);
var_dump("fruits: $fruits."); // 正常寫法解析變量
// string(23) "fruits: apple、banana."
var_dump("fruits: implode('、', ['apple', 'banana'])."); // 錯誤寫法不能夠解析函數
// string(44) "fruits: implode('、', ['apple', 'banana'])."
var_dump("fruits: ${!${''} = implode('、', ['apple', 'banana'])}."); // 特殊寫法解析函數成功
// string(23) "fruits: apple、banana."
var_dump("fruits: ${!${''} = implode('、',
[
'apple',
'banana'
])}."
); // 多行書寫依然解析函數成功
// string(23) "fruits: apple、banana."
二、
var_dump("fruits: ${!${''} = $fruit ?? 'apple'}.");
// string(14) "fruits: apple."
var_dump("fruits: ${!${''} = isset($fruit) ? $fruit : 'apple'}.");
// string(14) "fruits: apple."
三、
$fruit = function (){
return 'banana';
};
var_dump("fruits: ${!${''} = $fruit() }.");
// string(15) "fruits: banana."
var_dump("fruits: ${!${''} = call_user_func(function (){
$fruits = [
'apple',
'banana'
];
return implode('、', $fruits);
}) }.");
// string(23) "fruits: apple、banana."
四、
class Fruit
{
public function __toString()
{
return 'banana';
}
}
var_dump("fruits: ${!${''} = new Fruit() }.");
// string(15) "fruits: banana."
如果你想開發小程式或者app軟體的話,可以通過第三方專業開發平台,來幫助你實作開發需求:
廈門在乎科技-專注
廈門小程式開發公司、app開發、網站開發、h5小遊戲開發