看板 PHP 關於我們 聯絡資訊
關於建構子內的函數,若需要有值回傳。請問可以這麼用嗎? 有一 config.php ============================== <?php class config { function __construct() { $this->getvalue(); } function getvalue() { echo 'log'; //埋確定有進入函數的log return 10; } } ?> ============================== 然後我在主php去引用並使用config.php,想要得到裡面getvalue的回傳值。 但卻無法得到..,請問可能原因為何? main.php =========================================== <?php require_once __DIR__ . '/config.php'; $value = new config(); echo $value; ?> =========================================== echo 只會得到 'log'卻無法得到 return的值(10) 還是說其實問不能樣用呢,剛初學請各位大大幫忙,謝謝.. -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.163.89.30 ※ 文章網址: https://www.ptt.cc/bbs/PHP/M.1532398563.A.D83.html
MOONRAKER: 這是當然的好嗎,constructor不回傳東西 07/24 11:04
MOONRAKER: 你有什麼理由非要這樣 連多呼叫一個$value->getValue() 07/24 11:05
MOONRAKER: 都不想嗎 07/24 11:05
謝謝M大回覆~沒錯我去多呼叫可以解決!! 問題原由是因為我在處理連結資料庫的時候,有出現有連上,但無法query問題。 細找問題後,發現CONNECT根本沒有回傳,所以才衍生出這樣的提問。 https://blog.csdn.net/welovesunflower/article/details/7776438 裡面範例他有一個 db_connect.php ,相較於我上頭的config.php,準備提供引入用。 內容有斷如下: class DB_CONNECT { // constructor function __construct() { // connecting to database $this->connect(); //這裡用了類似作法 } function connect() { // import database connection variables require_once __DIR__ . '/db_config.php'; // Connecting to mysql database $con = mysql_connect(DB_SERVER, DB_USER, DB_PASSWORD) ...; .... // returing connection cursor return $con; //回傳connect //這裡用了類似作法 } 再來範例裡面有一個 get_all_products.php,相較於我的main.php, 裡面開頭如下: ============================================== ... // include db connect class require_once __DIR__ . '/db_connect.php'; // connecting to db $db = new DB_CONNECT(); //此處根本沒有得到值。 // get all products from products table $result = mysql_query("SELECT *FROM products") or die(mysql_error()) ... ============================================== $db因為沒有得到值,所以query不到。 當然如您建議我加個 $con = $db->connect(); 就沒問題了。 所以是不是其實真不該這樣寫呢? 應該明瞭了!!! 觀念問題,謝謝M大~
MOONRAKER: 這樣我就看不懂了 為什麼他的資料庫包裝會這樣 07/24 11:59
MOONRAKER: 一時想不通 但是什麼時候了還在用mysql_connect()這種 07/24 12:13
MOONRAKER: 爛招 新的php早就沒了 new會跑不出東西八成是這個原因 07/24 12:15
MOONRAKER: 趕快找個教用pdo連資料庫的文件來看吧 起碼也要mysqli 07/24 12:16
MOONRAKER: 依照他這種爛招 再connect()一次也沒有東西 07/24 12:16
!!! 原來有這東西!!謝謝M大指導!! ※ 編輯: goodsheng (118.163.89.30), 07/24/2018 13:25:40
MOONRAKER: 轉一下php.net正式文件的說明 http://bit.ly/2NHF4v9 07/24 13:54
MOONRAKER: 從php 5.5開始廢棄 7.0拿掉 如今php 7.2都出了 07/24 13:55
MOONRAKER: WAMP一類套件包當然不會再放舊的 雖然你要也是找得到 07/24 13:56
goodsheng: 好的!! mysqli或是PDO處理 07/24 13:59
xdraculax: $db 得到了 class 啊,return 是供額外呼叫用 07/25 01:20
xdraculax: 它的 __construct 也沒有 return $this->connect() 07/25 01:21
xdraculax: 你怎麼會誤以為它 $db 是想取 $con 07/25 01:22
xdraculax: mysql_query 沒代入 con 就是預設上一個連線 07/25 01:24
xdraculax: 範例並沒有錯應該要有資料,沒資料一定是別的有錯 07/25 01:25
xdraculax: 以上指正你 new class 的誤解而非說可繼續用 mysql_xx 07/25 01:29
MOONRAKER: 有啦昨晚有想出來 他是佔mysql_query()沒給連線物件 07/25 14:52
MOONRAKER: 就自動沿用最近那個的便宜 實在不可取 07/25 14:52
對,其實一開始也不認為他會return東西,因為他mysql_query並沒有要帶入$con。 而照理說接下來的操作應該要沿用所謂"預設上一個連線" 但實作後卻發現並沒有,他並沒有延用到,所以mysql接下來操作都沒有反應。 所以我就天真自己加了$db進去,天真以為$db有東西。 $result = mysql_query($db,"SELECT *FROM products") or die(mysql_error()) 想當然沒反應,$db不會有東西,因為如x大解說,return不回東西的。 但後來解決方式是再呼叫一次connect(),且也要帶入$con,才能成功,沒帶入不行。 $con = $db->connect(); $result = mysql_query($con,"SELECT *FROM products") or die(mysql_error()) 所以才會有建構內return的疑問.. 所以現在衍生的問題是: 1.一開始的方式,由建構來初始連線,但回主程式時,卻無法直接沿用後連線。 2.後來改再次呼叫connect()的方式,看起來也是無延續上一連線。必須要帶入$con。 看起來好像是同一問題,就副程式實體後的連線無法給主程式用? 但這問題可能也不是很重要,因為可以先用了.. (註:上述mysql我也都改成mysqli用了) 再次謝謝x大及M大~~ ※ 編輯: goodsheng (118.163.89.30), 07/26/2018 16:05:02