<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                ## 臨時 在php中我通常用一個版本數控制css js的版本 但是這么做每次更新版本要手動修改php文件 有沒有什么好的版本 不用改php文件 看 海豚php的minify ***** ### 小心看不見的字符 http://www.it1352.com/532564.html (Programmatically Lighten or Darken a hex color (or rgb, and blend colors)) ```php function shadeColor2($color, $percent) { $color = str_replace("#", "", $color); $t=$percent<0?0:255; $p=$percent<0?$percent*-1:$percent; $RGB = str_split($color, 2); $R=hexdec($RGB[0]); $G=hexdec($RGB[1]); $B=hexdec($RGB[2]); return '#'.substr(dechex(0x1000000+(round(($t-$R)*$p)+$R)*0x10000+(round(($t-$G)*$p)+$G??)*0x100+(round(($t-$B)*$p)+$B)),1); } ``` +$G??) 就有幾個看不見的字符,復制到編輯器中,將光標插入中間,你會發現需要按幾次方向鍵才能移動光標,說明那個位置有看不見的字符。 代碼運行時會出錯,提示該變量 ` $G? ` 不存在 要小心這種看不見的變量,如果別人將惡意代碼藏入其中就非常危險了,所以信賴網上舶來的代碼是一種危險的冒險。 * * * * * ~~~php $node = null; var_dump($node[1]); // 這樣竟然不會報錯 $node2 = []; var_dump($node2[1]); // 這樣就會報錯 未定義數組下標: 1 var_dump($node3); // 這樣會報錯 未定義變量 var_dump($node4[1]); // 這樣也會報錯 未定義數組下標: 1 ~~~ ***** ### 注意負數這樣判斷不是false哦 if判斷的條件中,如果條件是非0的正數或者負數,那么if中的代碼都能執行,如果if為0則不執行,加上!則相反 當轉換為 boolean 時,以下值被認為是 FALSE: 布爾值 FALSE 本身 整型值 0(零) 浮點型值 0.0(零) 空字符串,以及字符串 "0" 不包括任何元素的數組 特殊類型 NULL(包括尚未賦值的變量) 從空標記生成的 SimpleXML 對象 所有其它值都被認為是 TRUE(包括任何資源 和 NAN)。 [PHP: Boolean 布爾類型 - Manual](http://php.net/manual/zh/language.types.boolean.php) 負數不會被自動轉換為false哦,這可跟我們想的不太一樣哦。 ```php if (-1) { echo 1; //這里的1會被輸出 } $cost = $request->param('cost/f', 0); // 注意負數這樣判斷不是false 哦 if (!$cost) { throw new \Exception('請設置代理升級費用!'); } // 應該為 if (!$cost || $cost < 0) { throw new \Exception('請設置代理升級費用!'); } ``` * * * * * ~~~php $a = '0.00'; if (empty($a)) { echo 'empty'; } // 0.00 是空的,但是'0.00'不是空的,請注意這點。 ~~~ * * * * * ### 正則表達式的威力,要小心! ~~~php 要匹配1或者2,你可能會這樣寫正則: if (preg_match('/^1|2$/', 1122)) { echo '1'; } 沒想到卻匹配了,這有什么問題,咋一看還發現不了什么問題,為什么會出現這種結果呢? 你忽視了它的威力,| 用于或匹配,這里它沒有按你預想的發展,其實他匹配成了,以1開頭或者2結尾的數字了,它將^ $也匹配進去了,這是你沒想到的吧!所以小心它的威力,我們要給它明確的邊界它才能按照預期的發展,改進下就可以了: if (preg_match('/^(1|2)$/', 1122)) { echo '1'; } 或者 if (preg_match('/^[1|2]$/', 1122)) { echo '1'; } ~~~ * * * * * 細說php 1 ![](https://box.kancloud.cn/4356cb599ecb107a25a848d1b139e0fc_894x151.png) 2 字符串的邊界限定(分割)為換行,單詞的邊界限定(分割)為空格。 (字符串約定用換行符來區分,單詞以空格分開為準) ![](https://box.kancloud.cn/41a162da064a9a1a8972b96d5badf6dc_905x443.png) 3 非捕獲元字符 ![](https://box.kancloud.cn/4e210c90d5e261ad477c6b22fcdf1b10_913x555.png) * * * * * ### 數據新增和修改使用同一個控制器和同一個模板,你還在這么做嗎? 很多程序修改和新增使用同一個控制器,同一個模板,雖然這兩種操作模板基本相同,但是復雜的功能頁面,新增和更新在代碼邏輯上是有很大的不同的,寫在一起代碼不好維護,所以這種用一個控制器,模板完全沒必要,哪怕兩個模板基本一樣,但是這樣后期維護就會省很多事。 比如釘釘項目,廣告新增和更新模板基本一樣,邏輯很大部分也有重疊,但是異同之處也很多,代碼邏輯本身就復雜,在兩種操作寫在一起,那就會非常混亂了,增大出錯的可能性,調試維護將會很麻煩,所以還是分開寫比較好,不要為了節約一個方法,一個模板,養成良好的規范,在項目維護上會輕松很多。 復用是有代價的。 * * * * * ### 注意業務邏輯和sql結合的細節意義 sql 的 join中的“where”和where語句是有本質區別的,雖然看上去前者也是一種where,但是它受LEFT(INNER 、LEFT 、RIGHT 、FULL )的影響,而后者則不受LEFT的控制了,所以兩者有天壤之別的區別,一定要區分對待和理解。 where()相當于INNER,不過要知道這兩者的意義不同,所以為了邏輯語義,還是要嚴格安裝業務來寫,不能隨便寫,雖然結果是對的,但是意義是錯的。 寫代碼追求的不僅僅是結果是對的而已,還要思路,邏輯是對的。 ```php // 列出學校列表,并計算每列是否關聯了$schoolAdminId,admin_id為null則說明沒有關聯 $schoolList = Db::name(implode($mainTable, ' ')) ->join('school_admin_join s_a_j', 's_a_j.school_id = ' . $mainTable[1] . '.id and s_a_j.admin_id = ' . $schoolAdminId, 'LEFT') ->field($mainTable[1] . '.*,s_a_j.admin_id') ->where($where) // ->where(['s_a_j.admin_id' => $schoolAdminId]) // 這樣使用邏輯就錯了 ->paginate($size, false, ['query' => $searchDate]); ``` * * * * * >[danger] 業務邏輯不能依賴于數據庫,哪怕是數據庫的唯一索引。程序中還是要盡最大能力做唯一限制和控制的,數據庫只是最后一道防線而已,對待業務邏輯不能有依賴于數據庫的想法。 * * * * * ### 優化代碼 ```php $replace = array(); foreach ($context as $key => $val) { $replace['{' . $key . '}'] = $val; } // interpolate replacement values into the message and return return strtr($message, $replace); 這可以改善array('{user_name}' => $userName);這樣不方便的,代碼要書寫得舒服才好。 ``` * * * * * ### 無法完全拋棄關系型數據庫 雖然nosql大火,但其實它是不能替代傳統的關系型數據庫的,就行輪船替代不了汽車。 業務數據的結構通常都是關系型數據結構,如表格數據那樣的。 表格 業務數據,對人們來說是最直觀的。 ***** last update:2018-11-5 05:21:20
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看