搜尋
首頁php框架YIIyii2 怎麼上傳圖片
yii2 怎麼上傳圖片Dec 07, 2019 pm 04:20 PM
yii2上傳圖片

yii2 怎麼上傳圖片

第一步:建立上傳類別基礎工作,具體請看:http://www.yiichina.com/tutorial/328

第二步:建置站一個product表,字段id,name,picurl.

第三步:GII產生PRODUCT 模型,類,視圖。

第四步:

main.css 放在frontend\web\css
.onedialog{position:absolute; left: 300px; top: 500px; z-index: 10; width: 700px; height: 400px;border
-radius:5px;
box-shadow:5px 2px 6px #000; border: 2px solid #666}
.oneiframe{ width: 100%; height: 100% }

main.js 放在frontend\web\assets

$(function(){
$('#product-picurl').click(function(){
$('#oneupload').remove();
$(&#39;<div>&#39;).appendTo($(&#39;body&#39;)).attr({"class":"onedialog",&#39;id&#39;:"oneupload"});
$(&#39;<iframe>&#39;).appendTo($(&#39;#oneupload&#39;)).attr({"src":"?r=upload","class":"oneiframe"})
});
    var v=$(&#39;#product-picurl&#39;).val();
if(v){
$(&#39;<img  alt="yii2 怎麼上傳圖片" >&#39;).attr({"src":v,"style":"height:50px"}).insertAfter($(&#39;#product-picurl&#39;));
}
});

然後在frontend\assets\AppAsset.php中註冊這兩個檔案

class AppAsset extends AssetBundle
{
    public $basePath = &#39;@webroot&#39;;
    public $baseUrl = &#39;@web&#39;;
    public $css = [
        &#39;css/site.css&#39;,
        &#39;css/main.css&#39;,
    ];
    public $js = [
        &#39;assets/main.js&#39;
    ];
    public $depends = [
        &#39;yii\web\YiiAsset&#39;,
        &#39;yii\bootstrap\BootstrapAsset&#39;,
    ];
}

UploadController.php

<?PHP
namespace frontend\controllers;
use Yii;
use yii\web\Controller;
use app\models\UploadForm;
use yii\web\UploadedFile;
class UploadController extends Controller
{
    public function actionIndex()
    {
        $model = new UploadForm();
        if (Yii::$app->request->isPost) {
            $model->file = UploadedFile::getInstance($model, &#39;file&#39;);
            if ($model->file && $model->validate()) {
                //$model->file->saveAs(&#39;uploads/&#39; . $model->file->baseName . &#39;.&#39; .$model->
                file->extension); 
                $fileName=&#39;uploads/&#39; . date("YmdHis") . &#39;.&#39; . $model->file->extension;
                $model->file->saveAs($fileName);
            }
            echo "<script src=&#39;assets/upload.js&#39;></script>;";
            echo "<script>";
            echo "var oneinput=parent.document.getElementById(&#39;product-picurl&#39;);";
            echo "parent.document.getElementById(&#39;product-picurl&#39;).value=&#39;".$fileName."&#39;;";
            echo "var oneupload = parent.document.getElementById(&#39;oneupload&#39;);";
            echo "var img = document.createElement(&#39;img&#39;);";
            echo "img.setAttribute(&#39;style&#39;, &#39;height:50px&#39;);";
            echo "img.src =&#39;".$fileName."&#39;;";
            echo "insertAfter(img,oneinput);";
            echo "oneupload.parentNode.removeChild(oneupload)";
            echo "</script>";
        }
        return $this->render(&#39;upload&#39;, [&#39;model&#39; => $model]);
    }
}
?>

#UploadForm.php

<?PHP
namespace app\models;
use yii\base\Model;
use yii\web\UploadedFile;
/**
 * UploadForm is the model behind the upload form.
 */
class UploadForm extends Model
{
    /**
     * @var UploadedFile file attribute
     */
    public $file;
    /**
     * @return array the validation rules.
     */
    public function rules()
    {
        return [
            [[&#39;file&#39;], &#39;file&#39;],
        ];
    }
}
?>

upload.php

#
<?php
use yii\widgets\ActiveForm;
?>
<?php $form = ActiveForm::begin([&#39;options&#39; => [&#39;enctype&#39; => &#39;multipart/form-data&#39;]]) ?>
<?= $form->field($model, &#39;file&#39;)->fileInput() ?>
<button>Submit</button>
<?php ActiveForm::end() ?>

PHP中文網,有大量免費的Yii入門教學,歡迎大家學習!

以上是yii2 怎麼上傳圖片的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
yii框架時間戳怎麼設置教程yii框架時間戳怎麼設置教程Mar 06, 2025 pm 02:18 PM

該教程展示了YII框架的時間戳管理。 IT使用TimestampBehavior詳細介紹自動創建的_AT和UPDATED_AT更新,提供自定義選項並將其與手動更新,數據庫觸發器進行比較和自定義BE

在雲本地環境中使用YII的最佳實踐是什麼?在雲本地環境中使用YII的最佳實踐是什麼?Mar 18, 2025 pm 04:39 PM

本文討論了在雲本地環境中部署YII應用程序的最佳實踐,並通過集裝,編排和安全措施專注於可擴展性,可靠性和效率。

yii和laravel框架比較 yii和laravel框架有什麼區別yii和laravel框架比較 yii和laravel框架有什麼區別Mar 06, 2025 pm 02:17 PM

本文比較了PHP框架YII和Laravel。 YII優先考慮速度和結構,而Laravel則強調開發人員的經驗和靈活性。 儘管兩者都處理大型應用程序,但YII提供了出色的原始性能,而LA

yii框架怎麼樣 yii框架是什麼yii框架怎麼樣 yii框架是什麼Mar 06, 2025 pm 02:20 PM

本文介紹了YII,這是一個高性能的PHP框架,非常適合大規模Web應用程序。 它強調了Yii的速度,安全性和健壯的體系結構(MVC),強調了其優勢比Laravel,Symfony和Cod等其他框架的優勢

yii框架的優缺點 yii框架的優點及原理一覽yii框架的優缺點 yii框架的優點及原理一覽Mar 06, 2025 pm 02:22 PM

本文分析了YII框架的優勢和劣勢。 它突出了Yii的高性能,穩健的安全性,快速的開發能力和可擴展性,但也指出了較小的PR的學習曲線和潛在的複雜性

yii框架和tp框架那個比較好 yii框架和tp框架的區別yii框架和tp框架那個比較好 yii框架和tp框架的區別Mar 06, 2025 pm 02:21 PM

本文比較了YII和ThinkPHP(TP)框架。 選擇取決於項目規模和開發人員的經驗。 Yii,健壯而成熟,適合大型,複雜的項目,需要高性能。 TP,更簡單,更快地開發,更好

yii怎麼調用公共函數 yii公共函數怎麼調用教程yii怎麼調用公共函數 yii公共函數怎麼調用教程Mar 06, 2025 pm 02:23 PM

本文詳細介紹瞭如何在YII應用程序中調用和組織共同功能。 它主張將功能封裝在類中,理想情況下,在專用的應用程序/助手目錄中,以提高可重複性和可維護性。 不同的方法

在無服務器體系結構中使用YII的關鍵注意事項是什麼?在無服務器體系結構中使用YII的關鍵注意事項是什麼?Mar 18, 2025 pm 04:33 PM

本文討論了在無服務器體系結構中使用YII的關鍵注意事項,專注於無狀態,冷啟動,功能大小,數據庫交互,安全性和監視。它還涵蓋優化策略和潛在的綜合

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),