詳解PHP的Yii框架中自帶的前端資源包的使用,yii框架_PHP教程
Jul 12, 2016 am 08:55 AM詳解PHP的Yii框架中自帶的前端資源包的使用,yii框架
Yii中的資源是和Web頁面相關的文件,可為CSS文件,JavaScript文件,圖片或視頻等, 資源放在Web可訪問的目錄下,直接被Web服務器調(diào)用。
通過程序自動管理資源更好一點,例如,當你在頁面中使用 yii\jui\DatePicker 小部件時, 它會自動包含需要的CSS和JavaScript文件,而不是要求你手工去找到這些文件并包含, 當你升級小部件時,它會自動使用新版本的資源文件,在本教程中,我們會詳述Yii提供的強大的資源管理功能。
資源包
Yii在資源包中管理資源,資源包簡單的說就是放在一個目錄下的資源集合, 當在視圖中注冊一個資源包,在渲染W(wǎng)eb頁面時會包含包中的CSS和JavaScript文件。
定義資源包
資源包指定為繼承yii\web\AssetBundle的PHP類,包名為可自動加載的PHP類名, 在資源包類中,要指定資源所在位置,包含哪些CSS和JavaScript文件以及和其他包的依賴關系。
如下代碼定義基礎應用模板使用的主要資源包:
<?php namespace app\assets; use yii\web\AssetBundle; class AppAsset extends AssetBundle { public $basePath = '@webroot'; public $baseUrl = '@web'; public $css = [ 'css/site.css', ]; public $js = [ ]; public $depends = [ 'yii\web\YiiAsset', 'yii\bootstrap\BootstrapAsset', ]; }
如上AppAsset 類指定資源文件放在 @webroot 目錄下,對應的URL為 @web,資源包中包含一個CSS文件 css/site.css,沒有JavaScript文件, 依賴其他兩個包 yii\web\YiiAsset 和 yii\bootstrap\BootstrapAsset, 關于yii\web\AssetBundle 的屬性的更多詳細如下所述:
- yii\web\AssetBundle::sourcePath: 指定包包含資源文件的根目錄, 當根目錄不能被Web訪問時該屬性應設置,否則,應設置 yii\web\AssetBundle::basePath 屬性和yii\web\AssetBundle::baseUrl。 路徑別名 可在此處使用;
- yii\web\AssetBundle::basePath: 指定包含資源包中資源文件并可Web訪問的目錄, 當指定yii\web\AssetBundle::sourcePath 屬性, 資源管理器 會發(fā)布包的資源到一個可Web訪問并覆蓋該屬性, 如果你的資源文件在一個Web可訪問目錄下,應設置該屬性,這樣就不用再發(fā)布了。 路徑別名 可在此處使用。
yii\web\AssetBundle::baseUrl: 指定對應到y(tǒng)ii\web\AssetBundle::basePath目錄的URL, 和 yii\web\AssetBundle::basePath 類似,如果你指定 yii\web\AssetBundle::sourcePath 屬性, 資源管理器 會發(fā)布這些資源并覆蓋該屬性,路徑別名 可在此處使用。
yii\web\AssetBundle::js: 一個包含該資源包JavaScript文件的數(shù)組,注意正斜杠"/"應作為目錄分隔符, 每個JavaScript文件可指定為以下兩種格式之一:
- 相對路徑表示為本地JavaScript文件 (如 js/main.js),文件實際的路徑在該相對路徑前加上 yii\web\AssetManager::basePath,文件實際的URL在該路徑前加上yii\web\AssetManager::baseUrl。
- 絕對URL地址表示為外部JavaScript文件,如 http://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js 或//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js.
- yii\web\AssetBundle::css: 一個包含該資源包JavaScript文件的數(shù)組,該數(shù)組格式和 yii\web\AssetBundle::js 相同。
- yii\web\AssetBundle::depends: 一個列出該資源包依賴的其他資源包(后兩節(jié)有詳細介紹)。
- yii\web\AssetBundle::jsOptions: 當調(diào)用yii\web\View::registerJsFile()注冊該包 每個 JavaScript文件時, 指定傳遞到該方法的選項。
- yii\web\AssetBundle::cssOptions: 當調(diào)用yii\web\View::registerCssFile()注冊該包 每個 css文件時, 指定傳遞到該方法的選項。
- yii\web\AssetBundle::publishOptions: 當調(diào)用yii\web\AssetManager::publish()發(fā)布該包資源文件到Web目錄時 指定傳遞到該方法的選項,僅在指定了yii\web\AssetBundle::sourcePath屬性時使用。
資源位置
資源根據(jù)它們的位置可以分為:
源資源: 資源文件和PHP源代碼放在一起,不能被Web直接訪問,為了使用這些源資源,它們要拷貝到一個可Web訪問的Web目錄中 成為發(fā)布的資源,這個過程稱為發(fā)布資源,隨后會詳細介紹。
發(fā)布資源: 資源文件放在可通過Web直接訪問的Web目錄中;
外部資源: 資源文件放在你的Web應用不同的Web服務器上;
當定義資源包類時候,如果你指定了yii\web\AssetBundle::sourcePath 屬性,就表示任何使用相對路徑的資源會被 當作源資源;如果沒有指定該屬性,就表示這些資源為發(fā)布資源(因此應指定yii\web\AssetBundle::basePath 和 yii\web\AssetBundle::baseUrl 讓Yii知道它們的位置)。
推薦將資源文件放到Web目錄以避免不必要的發(fā)布資源過程,這就是之前的例子指定 yii\web\AssetBundle::basePath 而不是 yii\web\AssetBundle::sourcePath.
對于 擴展來說,由于它們的資源和源代碼都在不能Web訪問的目錄下, 在定義資源包類時必須指定yii\web\AssetBundle::sourcePath屬性。
注意: yii\web\AssetBundle::sourcePath 屬性不要用@webroot/assets,該路徑默認為 yii\web\AssetManager資源管理器將源資源發(fā)布后存儲資源的路徑,該路徑的所有內(nèi)容會認為是臨時文件, 可能會被刪除。
資源依賴
當Web頁面包含多個CSS或JavaScript文件時,它們有一定的先后順序以避免屬性覆蓋, 例如,Web頁面在使用jQuery UI小部件前必須確保jQuery JavaScript文件已經(jīng)被包含了, 我們稱這種資源先后次序稱為資源依賴。
資源依賴主要通過yii\web\AssetBundle::depends 屬性來指定, 在AppAsset 示例中,資源包依賴其他兩個資源包: yii\web\YiiAsset 和 yii\bootstrap\BootstrapAsset 也就是該資源包的CSS和JavaScript文件要在這兩個依賴包的文件包含 之后 才包含。
資源依賴關系是可傳遞,也就是人說A依賴B,B依賴C,那么A也依賴C。
資源選項
可指定yii\web\AssetBundle::cssOptions 和 yii\web\AssetBundle::jsOptions 屬性來自定義頁面包含CSS和JavaScript文件的方式, 這些屬性值會分別傳遞給 yii\web\View::registerCssFile() 和 yii\web\View::registerJsFile() 方法, 在視圖 調(diào)用這些方法包含CSS和JavaScript文件時。
注意: 在資源包類中設置的選項會應用到該包中 每個 CSS/JavaScript 文件,如果想對每個文件使用不同的選項, 應創(chuàng)建不同的資源包并在每個包中使用一個選項集。
例如,只想IE9或更高的瀏覽器包含一個CSS文件,可以使用如下選項:
public $cssOptions = ['condition' => 'lte IE9'];
這會是包中的CSS文件使用以下HTML標簽包含進來:
<!--[if lte IE9]> <link rel="stylesheet" href="path/to/foo.css"> <![endif]-->
為鏈接標簽包含

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Kaedah teras untuk membina fungsi perkongsian sosial dalam PHP adalah untuk menghasilkan pautan perkongsian secara dinamik yang memenuhi keperluan setiap platform. 1. Mula -mula dapatkan halaman semasa atau URL dan maklumat artikel yang ditentukan; 2. Gunakan urlencode untuk menyandikan parameter; 3. Sambutan dan menjana pautan perkongsian mengikut protokol setiap platform; 4. Pautan paparan di hujung depan untuk pengguna mengklik dan berkongsi; 5. Dinamik menghasilkan tag OG pada halaman untuk mengoptimumkan paparan kandungan perkongsian; 6. Pastikan untuk melepaskan input pengguna untuk mencegah serangan XSS. Kaedah ini tidak memerlukan pengesahan yang kompleks, mempunyai kos penyelenggaraan yang rendah, dan sesuai untuk kebanyakan keperluan perkongsian kandungan.

Untuk merealisasikan pembetulan ralat teks dan pengoptimuman sintaks dengan AI, anda perlu mengikuti langkah -langkah berikut: 1. Pilih model AI atau API yang sesuai, seperti Baidu, Tencent API atau perpustakaan NLP sumber terbuka; 2. Panggil API melalui curl atau Guzzle PHP dan memproses hasil pulangan; 3. Maklumat pembetulan ralat paparan dalam aplikasi dan membenarkan pengguna memilih sama ada untuk mengadopsinya; 4. Gunakan php-l dan php_codesniffer untuk pengesanan sintaks dan pengoptimuman kod; 5. Secara berterusan mengumpul maklum balas dan mengemas kini model atau peraturan untuk meningkatkan kesannya. Apabila memilih AIAPI, fokus pada menilai ketepatan, kelajuan tindak balas, harga dan sokongan untuk PHP. Pengoptimuman kod harus mengikuti spesifikasi PSR, gunakan cache yang munasabah, elakkan pertanyaan bulat, mengkaji semula kod secara berkala, dan gunakan x

Phpisstillrelevantinmodernenterpriseenvironments.1.modernphp (7.xand8.x) Menawarkan Perpaduan Perlengkapan, ketegangan, jitcompilation, danmodernsyntax, makeitsuatableforlarge-scaleapplications.2.phpintegratefective

Elakkan masalah pertanyaan n 1, mengurangkan bilangan pertanyaan pangkalan data dengan memuatkan data yang berkaitan terlebih dahulu; 2. Pilih hanya medan yang diperlukan untuk mengelakkan memuat entiti lengkap untuk menjimatkan memori dan jalur lebar; 3. Gunakan strategi cache yang munasabah, seperti cache sekunder doktrin atau hasil pertanyaan frekuensi tinggi Cache; 4. Mengoptimumkan kitaran hayat entiti dan panggilan jelas () secara teratur untuk membebaskan memori untuk mengelakkan limpahan memori; 5. Memastikan indeks pangkalan data wujud dan menganalisis penyata SQL yang dihasilkan untuk mengelakkan pertanyaan yang tidak cekap; 6. Lumpuhkan penjejakan perubahan automatik dalam senario di mana perubahan tidak diperlukan, dan gunakan array atau mod ringan untuk meningkatkan prestasi. Penggunaan ORM yang betul memerlukan menggabungkan pemantauan SQL, caching, pemprosesan batch dan pengoptimuman yang sesuai untuk memastikan prestasi aplikasi sambil mengekalkan kecekapan pembangunan.

Untuk membina microservice PHP yang fleksibel, anda perlu menggunakan RabbitMQ untuk mencapai komunikasi asynchronous, 1. Decouple perkhidmatan melalui beratur mesej untuk mengelakkan kegagalan cascade; 2. Konfigurasi beratur berterusan, mesej berterusan, pengesahan pelepasan dan ACK manual untuk memastikan kebolehpercayaan; 3. Menggunakan Backoff Exponential Backoff, TTL dan Kegagalan Pemprosesan Keselamatan Gilir Surat Dead; 4. Gunakan alat seperti penyelia untuk melindungi proses pengguna dan membolehkan mekanisme degupan jantung untuk memastikan kesihatan perkhidmatan; dan akhirnya menyedari keupayaan sistem untuk terus beroperasi dalam kegagalan.

Gunakan subprocess.run () untuk melaksanakan perintah shell dengan selamat dan menangkap output. Adalah disyorkan untuk lulus parameter dalam senarai untuk mengelakkan risiko suntikan; 2. Apabila ciri -ciri shell diperlukan, anda boleh menetapkan shell = benar, tetapi berhati -hati dengan suntikan arahan; 3. Gunakan subprocess.popen untuk merealisasikan pemprosesan output masa nyata; 4. Tetapkan semak = benar untuk membuang pengecualian apabila arahan gagal; 5. Anda boleh secara langsung memanggil rantai untuk mendapatkan output dalam senario mudah; Anda harus memberi keutamaan kepada subprocess.run () dalam kehidupan seharian untuk mengelakkan menggunakan os.system () atau modul yang tidak ditetapkan. Kaedah di atas mengatasi penggunaan teras untuk melaksanakan perintah shell di Python.

Menggunakan imej asas PHP yang betul dan mengkonfigurasi persekitaran docker yang dioptimumkan prestasi yang selamat adalah kunci untuk mencapai pengeluaran siap. 1. Pilih PHP: 8.3-fpm-alpine sebagai imej asas untuk mengurangkan permukaan serangan dan meningkatkan prestasi; 2. Lumpuhkan fungsi berbahaya melalui php.ini adat, matikan paparan ralat, dan aktifkan Opcache dan JIT untuk meningkatkan keselamatan dan prestasi; 3. Gunakan nginx sebagai proksi terbalik untuk menyekat akses kepada fail sensitif dan memajukan permintaan PHP dengan betul kepada PHP-FPM; 4. Gunakan imej pengoptimuman pelbagai peringkat untuk menghapuskan kebergantungan pembangunan, dan menubuhkan pengguna bukan akar untuk menjalankan bekas; 5. Supervisord pilihan untuk menguruskan pelbagai proses seperti Cron; 6. Sahkan bahawa tiada kebocoran maklumat sensitif sebelum penggunaan

Fail Tetapan.JSON terletak di laluan peringkat pengguna atau ruang kerja dan digunakan untuk menyesuaikan tetapan vscode. 1. Laluan peringkat pengguna: Windows adalah C: \ Users \\ AppData \ Roaming \ code \ user \ settings.json, macOS adalah /users//library/applicationsupport/code/user/settings.json, linux adalah/ 2. Laluan Tahap Ruang Kerja: .VSCODE/Tetapan dalam Direktori Root Projek
