[心得] CI不死…

看板PHP作者 (I'm 邱老虎)時間11年前 (2014/07/15 23:48), 編輯推噓6(608)
留言14則, 9人參與, 最新討論串1/2 (看更多)
雖然CI很久沒更新了…(我也離開寫程式行業二~三年) 不過近四個月,也越來越有心得,後來就慢慢找到自己的習慣開發方式 我自己個人: 【Model】 負責與資料庫,所以幾乎會寫概觀的通用性 通常會有: get_list($where, $limit, $offset, $order) 用來分頁/列表用 get_where($where) 取得單一資料 on_duplicate_batch($data) 資料新增與更新 delete($where)、add($data)、update($data, $where) 後面的新增和更新幾乎都很少用了 【Libs】 介於model和controller中間 把model的功能性除原本的,也做更多擴充,做更多細項 get_list_rows($where) =>> model->get_list($where)->num_rows() get_by_id($id) =>> model->get_where(array('id' => $id )) on_duplicate($data) =>> modetl->on_duplicate_batch(array(0 => $data)) delete_by_id($id) =>> model_delete(array('id' => $id )) 【Controller】 現在習慣CUID就分成: list_all($page) 會對應到Libs的get_list,然後做分頁功能 add 餵一個假資料到view alter($id) 對應到Libs的get_by_id save($ajax) 這部份寫成可以用ajax處理,或是post,再以Libs的on_duplicate 【View】 以add、alter為例,會共用同一個view, 在js檢查完後,直接以 var data = { field : field_data } 送到Controller的save,只需要$this->input->post($data),接收後, 用on_duplicate就可以存入了,而不需各別接收每個欄位變數 【其他變形】 常常網頁開發會遇到資料欄位不統一情況,然後就會浪費去多開一個資料表 實際上資料表不會存超過十筆XDDDDDD 這部份我就以json來儲存,資料表規劃會如下: id:資料表編號 type: 屬於哪一種資料型態 data: 資料內容,這部份就以json型態存入 例:[{id:0, name:''},{id:1, name:''}] 所以在Libs裡,就會寫上一個存入/取出的function function get($type){ $result = model->get_where(array('type' => $type))->result_array() $result[0]['content'] = json_decode($resulst[0]['content'], TRUE) return $result[0] } function on_duplicate($data){ $data['content'] = json_encode($data['content']); model->on_duplicate_batch(array(0 => $data)) } 而在controller可以寫一個通用的: function uni_save($ajax = TRUE){ $flag = 1 $data = $this->input->post('data'); Libs->on_duplicate($data) $ary = array('flag' => $flag) if($ajax)echo $ary; else return $ary; } 在view裡: js則是以這樣寫 var data = [] $('.data_area').each(function(index){ var tmp ={ 'id' : index, 'name' : $(this).find('.name').val() } data.push(tmp) }); var ary = { 'id' : $('#id').val() 'type' : $('#type').val() 'data' : data } $.ajax{ data: { 'data' : ary} url : controller/save } 不過這種通用的有最大缺點就是,無法針對個別做刪除, 只能每次做更新, 個人拿來的用途是:廣告的圖片和連結、產品的分類、郵遞區號等 泛用性算是非常廣XD 差不多是這樣啦,相信還有更好的寫法... -- 當對一切絕望的時候, 這時候的樂觀,只是從悲觀所堆積出來:) -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 27.105.39.7 ※ 文章網址: http://www.ptt.cc/bbs/PHP/M.1405439293.A.393.html

07/16 01:23, , 1F
去玩個Rails吧:)
07/16 01:23, 1F

07/16 01:40, , 2F
去玩nodejs吧:)
07/16 01:40, 2F

07/16 05:28, , 3F
nodejs…搭no-sql db真的很好用= =……
07/16 05:28, 3F

07/16 07:55, , 4F
推一個!曾是 CI 人,現在 Laravel
07/16 07:55, 4F

07/17 11:23, , 5F
不玩玩看我嗎XD
07/17 11:23, 5F

07/17 13:00, , 6F
Laravel之前有小碰,但說明文件不是很親民…(遮臉
07/17 13:00, 6F

07/17 17:27, , 7F
symfony也不錯啊..
07/17 17:27, 7F

07/17 17:28, , 8F
symfony玩熟了還可以跨入drupal8 module 開發咧
07/17 17:28, 8F

07/17 18:57, , 9F
我覺得lara的文件和相關資源很完整,台灣社群也蠻活絡,很
07/17 18:57, 9F

07/17 18:57, , 10F
值得考慮
07/17 18:57, 10F

07/18 00:02, , 11F
(握住j87b0003的手)
07/18 00:02, 11F

07/18 09:12, , 12F
來試試Symfony吧,文件齊全到看不完 XD (握住一堆人的手)
07/18 09:12, 12F

07/18 10:12, , 13F
推 symfony 之前出差也用了一陣子,滿不錯的...
07/18 10:12, 13F

07/18 21:54, , 14F
大家手牽手圍一圈,來淨化什麼東西吧(握手
07/18 21:54, 14F
文章代碼(AID): #1JnKqzEJ (PHP)
討論串 (同標題文章)
以下文章回應了本文
完整討論串 (本文為第 1 之 2 篇):
6
14
文章代碼(AID): #1JnKqzEJ (PHP)