亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Home php教程 php手冊 PHP:MVC迷思

PHP:MVC迷思

Jun 21, 2016 am 09:14 AM
desktop http java mvc php

近來設(shè)計(jì)模式風(fēng)行,MVC隨處可見,PHP領(lǐng)域也不例外,很多論壇都開始討論在PHP中使用MVC。然而,M、V、C在PHP中到底該如何實(shí)現(xiàn)?MVC真的適合PHP么?這里Easy給出一些自己的思考。


MVC的原型

MVC本來是存在于Desktop程序中的,M是指數(shù)據(jù)模型,V是指用戶界面,C則是控制器。使用MVC的目的是將M和V的實(shí)現(xiàn)代碼分離,從而使同一個(gè)程序可以使用不同的表現(xiàn)形式。比如一批統(tǒng)計(jì)數(shù)據(jù)你可以分別用柱狀圖、餅圖來表示。C存在的目的則是確保M和V的同步,一旦M改變,V應(yīng)該同步更新。


JAVA中的MVC

JAVA把MVC引入了Web領(lǐng)域,并在此基礎(chǔ)上架構(gòu)出了一套稱為Model2的體系。由于Web的特殊性,JAVA中的MVC和Desktop中的MVC并不完全一致。主要原因是Web中的V不是持續(xù)的,用戶每訪問一次,V就要重新生成一次,所以V始終是和M一致的,不需要C來控制同步。那么JAVA中的C在干什么?JAVA中的C通常用于流程的轉(zhuǎn)向,其實(shí)用的是Dispatch模式,不再是Desktop中的C了。



PHP中的MVC

要在PHP中原封不動(dòng)的COPY JAVA的MVC是不可能的。問題主要表現(xiàn)在M上,在JAVA中,M是獨(dú)立于業(yè)務(wù)邏輯和表現(xiàn)邏輯的數(shù)據(jù)模型,在服務(wù)器端跨頁面存在,JAVA Bean扮演的就是這個(gè)腳色。而PHP進(jìn)程并不長時(shí)間駐留于內(nèi)存,只在PHP頁面開始執(zhí)行時(shí)創(chuàng)建,在頁面解釋執(zhí)行結(jié)束時(shí)就已經(jīng)結(jié)束。在這樣的情況下,我們根本無法直接實(shí)現(xiàn)M。所以所有聲稱實(shí)現(xiàn)了MVC模式的PHP程式都只能通過模擬手段來實(shí)現(xiàn)M。實(shí)現(xiàn)的方式一般是在當(dāng)前頁面結(jié)束前把數(shù)據(jù)存入數(shù)據(jù)庫或者cookie/session,在下一個(gè)頁面中再透過數(shù)據(jù)庫或者cookie/session重建M。這樣的方式和JAVA中的Bean比起來可以說是開銷巨大,本來往內(nèi)存中寫數(shù)據(jù)的簡單操作現(xiàn)在要從服務(wù)器端傳到客戶端或者數(shù)據(jù)庫,然后再傳回來。與其用這么大的開銷來維護(hù)一個(gè)數(shù)據(jù)模型再在最后把這個(gè)模型塞回?cái)?shù)據(jù)庫,還不如直接根據(jù)需要更新數(shù)據(jù)庫里邊的數(shù)據(jù)。

現(xiàn)在PHP中的MVC架構(gòu)可以用下圖來表示。





然后我們再來看V?,F(xiàn)在很多PHP程序簡單的使用了一些模板技術(shù)就在說明中寫“采用MVC架構(gòu)”。其實(shí)絕大多數(shù)的PHP模板程序都只是分離HTML和PHP的,而非MVC強(qiáng)調(diào)的顯示邏輯和業(yè)務(wù)邏輯分離。一個(gè)混用HTML和PHP的頁面一樣可以是MVC的一部份。如何分離顯示邏輯和業(yè)務(wù)邏輯至今沒有一個(gè)滿意的方案。我個(gè)人則比較認(rèn)同http://www.phpe.net/articles/384.shtml的實(shí)現(xiàn)方案。至于C,和JAVA中差不多,還是被用作轉(zhuǎn)向,這個(gè)在PHP中其實(shí)并不重要。


一個(gè)極耗資源的M + 一個(gè)區(qū)別不大的V + 可有可無的C 構(gòu)成了PHP中所謂的MVC。

基于以上分析,Easy認(rèn)為,PHP原有的3層構(gòu)架比所謂的MVC更為高效,而3層構(gòu)架中的表現(xiàn)層要解決的問題MVC中的V也同樣存在。一個(gè)改進(jìn)后的3層架構(gòu)比MVC更適用于PHP。

PS:有的方案把業(yè)務(wù)邏輯并入M中(http://www.phpe.net/articles/382.shtml),這其實(shí)是MVC的思想背道而馳的。

更多相關(guān)討論請到討論區(qū):http://club.phpe.net/index.php?act=ST&f=15&t=4720



Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

PHP Tutorial
1488
72
VSCode settings.json location VSCode settings.json location Aug 01, 2025 am 06:12 AM

The settings.json file is located in the user-level or workspace-level path and is used to customize VSCode settings. 1. User-level path: Windows is C:\Users\\AppData\Roaming\Code\User\settings.json, macOS is /Users//Library/ApplicationSupport/Code/User/settings.json, Linux is /home//.config/Code/User/settings.json; 2. Workspace-level path: .vscode/settings in the project root directory

How to handle transactions in Java with JDBC? How to handle transactions in Java with JDBC? Aug 02, 2025 pm 12:29 PM

To correctly handle JDBC transactions, you must first turn off the automatic commit mode, then perform multiple operations, and finally commit or rollback according to the results; 1. Call conn.setAutoCommit(false) to start the transaction; 2. Execute multiple SQL operations, such as INSERT and UPDATE; 3. Call conn.commit() if all operations are successful, and call conn.rollback() if an exception occurs to ensure data consistency; at the same time, try-with-resources should be used to manage resources, properly handle exceptions and close connections to avoid connection leakage; in addition, it is recommended to use connection pools and set save points to achieve partial rollback, and keep transactions as short as possible to improve performance.

Mastering Dependency Injection in Java with Spring and Guice Mastering Dependency Injection in Java with Spring and Guice Aug 01, 2025 am 05:53 AM

DependencyInjection(DI)isadesignpatternwhereobjectsreceivedependenciesexternally,promotingloosecouplingandeasiertestingthroughconstructor,setter,orfieldinjection.2.SpringFrameworkusesannotationslike@Component,@Service,and@AutowiredwithJava-basedconfi

python itertools combinations example python itertools combinations example Jul 31, 2025 am 09:53 AM

itertools.combinations is used to generate all non-repetitive combinations (order irrelevant) that selects a specified number of elements from the iterable object. Its usage includes: 1. Select 2 element combinations from the list, such as ('A','B'), ('A','C'), etc., to avoid repeated order; 2. Take 3 character combinations of strings, such as "abc" and "abd", which are suitable for subsequence generation; 3. Find the combinations where the sum of two numbers is equal to the target value, such as 1 5=6, simplify the double loop logic; the difference between combinations and arrangement lies in whether the order is important, combinations regard AB and BA as the same, while permutations are regarded as different;

python pytest fixture example python pytest fixture example Jul 31, 2025 am 09:35 AM

fixture is a function used to provide preset environment or data for tests. 1. Use the @pytest.fixture decorator to define fixture; 2. Inject fixture in parameter form in the test function; 3. Execute setup before yield, and then teardown; 4. Control scope through scope parameters, such as function, module, etc.; 5. Place the shared fixture in conftest.py to achieve cross-file sharing, thereby improving the maintainability and reusability of tests.

How to work with Calendar in Java? How to work with Calendar in Java? Aug 02, 2025 am 02:38 AM

Use classes in the java.time package to replace the old Date and Calendar classes; 2. Get the current date and time through LocalDate, LocalDateTime and LocalTime; 3. Create a specific date and time using the of() method; 4. Use the plus/minus method to immutably increase and decrease the time; 5. Use ZonedDateTime and ZoneId to process the time zone; 6. Format and parse date strings through DateTimeFormatter; 7. Use Instant to be compatible with the old date types when necessary; date processing in modern Java should give priority to using java.timeAPI, which provides clear, immutable and linear

Understanding the Java Virtual Machine (JVM) Internals Understanding the Java Virtual Machine (JVM) Internals Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

Using PHP for Data Scraping and Web Automation Using PHP for Data Scraping and Web Automation Aug 01, 2025 am 07:45 AM

UseGuzzleforrobustHTTPrequestswithheadersandtimeouts.2.ParseHTMLefficientlywithSymfonyDomCrawlerusingCSSselectors.3.HandleJavaScript-heavysitesbyintegratingPuppeteerviaPHPexec()torenderpages.4.Respectrobots.txt,adddelays,rotateuseragents,anduseproxie

See all articles