最近做了一個項目,這個項目中需要實現(xiàn)的一個功能是:用戶自定義頭像(用戶在本地選擇一張圖片,在本地將圖片裁剪成滿足系統(tǒng)要求尺寸的大?。?。這個功能的需求是:頭像最初剪切為一個正方形。如果選擇的圖片小于規(guī)定的頭像要求尺寸,那么這整張圖片都會作為頭像。如果大于規(guī)定的尺寸,那么用戶可以選擇要裁剪的區(qū)域。用戶點擊確定按鈕,就將裁剪得到的圖片數(shù)據(jù)發(fā)送到服務器,在后端將圖片數(shù)據(jù)保存成一個文件。
成都創(chuàng)新互聯(lián)客戶idc服務中心,提供德陽機房托管、成都服務器、成都主機托管、成都雙線服務器等業(yè)務的一站式服務。通過各地的服務中心,我們向成都用戶提供優(yōu)質廉價的產(chǎn)品以及開放、透明、穩(wěn)定、高性價比的服務,資深網(wǎng)絡工程師在機房提供7*24小時標準級技術保障。要完成上述功能,涉及到的知識有:ajax,canvas和html5中的files接口。我將實現(xiàn)這個功能的代碼封裝到了4個模塊中,分別是ajax.js,preview.js,shear.js和customerImg.js。
ajax.js:用于發(fā)送ajax請求。
preview.js:用于圖片預覽
shear.js:用于裁剪圖片
customer.js:自定義頭像。在這個模塊中藥引入ajax.js,preview.js和shear.js
我使用webpack進行打包。我還使用了jquery和jquery-ui。
我從這個項目中抽離出了這個功能。下面是這個功能的詳細代碼。
1.HTML代碼
<div class="m-warp" id="warp"> <div class="item"> <input type="file" name="img" id="img" hidden> <label for="img">選擇圖片</label> </div> <div class="item clearfix"> <div class="col col-1"> <div class="preview" id="preview"> <div class="mask"></div> <canvas class="cvsMove" id="cvsMove"></canvas> </div> </div> <div class="thum col-2 col"> <p>預覽</p> <img src="" id="thum"> <p class="f-text-l f-marTop-20"> <button class="shear" id="submit">確定</button> </p> </div> </div> </div>
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站aaarwkj.com,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網(wǎng)站欄目:基于HTML5+JS實現(xiàn)本地圖片裁剪并上傳功能-創(chuàng)新互聯(lián)
分享路徑:http://aaarwkj.com/article24/dpisce.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供手機網(wǎng)站建設、網(wǎng)站營銷、響應式網(wǎng)站、全網(wǎng)營銷推廣、微信小程序、網(wǎng)站設計
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)