vue項目代碼改進(一)login組件

Login登錄組件

1. 新增登錄頭像(css樣式回顧)

1)div.avatar
2)子絕父相定位,left…top…
3)border
4)placeholder
5)box-shadow

box-shadow: offset-x offset-y blur spread color inset;
參數解釋:
[X軸偏移量]offset-x:必需,取值正負都可。offset-x水平陰影的位置。
[Y軸偏移量] offset-y:必需,取值正負都可。offset-y垂直陰影的位置。
[陰影模糊半徑]blur:可選,只能取正值。blur-radius陰影模糊半徑,0即無模糊效果,值越大陰影邊緣越模糊。
[陰影擴展]spread:可選,取值正負都可。spread代表陰影的周長向四周擴展的尺寸,正值,陰影擴大,負值陰影縮小。
[陰影顏色]color:可選。陰影的顏色。如果不設置,瀏覽器會取默認顏色,通常是黑色,但各瀏覽器默認顏色有差異,建議不要省略。可以是rgb(250,0,0),也可以是有透明值的rgba(250,0,0,0.5)。
[投影方式]inset:可選。關鍵字,將外部投影(默認outset)改為內部投影。inset 陰影在背景之上,內容之下。

6)flex布局(添加重置按鈕)

.login-wrap .login_btns { ---- 容器樣式display: flex;justify-content: center;
}
.login-btn { ---- 項目樣式flex-grow: 1;
}
<el-row class="login_btns"> ---- 容器<el-button type="primary" class="login-btn" @click="handleLogin">登錄</el-button> ---- 項目<el-button type="info" class="login-btn" @click="handleLogin">重置</el-button>
</el-row>

以下6個屬性設置在容器上。
flex-direction;
flex-wrap;
flex-flow;
align-items;
align-content;
justify-content :
①flex-start(默認值):左對齊
②flex-end:右對齊
③center:居中
④space-between:兩端對齊,項目之間的間隔都相等
⑤space-around:每個項目兩側的間隔相等。所以,項目之間的間隔比項目與邊框的間隔大一倍。

2. element-UI input組件參數

el-input
1.密碼框:使用show-password屬性
2.帶 icon 的輸入框:
1)prefix-icon 屬性在 input 組件首部增加顯示圖標;
2)suffix-icon 屬性在 input 組件尾部增加顯示圖標;
3)通過 slot 來放置圖標
<i slot="prefix" class="el-input__icon el-icon-search"> </i>

flex布局參考

3. element-UI form組件

表單驗證(對輸入的用戶名/密碼做簡單的長度/非空驗證)

只需要通過 rules 屬性傳入約定的驗證規則,并將 Form-Item 的 prop 屬性設置為需校驗的字段名即可。

<el-form 
:model="formdata" 
:rules="rules" 
ref="formdata"><el-form-item label="用戶名" -- 給label綁定propprop="username"></el-form-item><el-row class="login_btns"><el-button @click="handleLogin('formdata')">登錄</el-button><el-button @click="resetForm('formdata')">重置</el-button></el-row>
</el-form>
data中
rules: {username: [{ required: true, message: '請輸入用戶名', trigger: 'blur' },{ min: 3, max: 5, message: '長度在 3 到 5 個字符', trigger: 'blur' }],// 登錄密碼的校驗規則password: [{ required: true, message: '請輸入登錄密碼', trigger: 'blur' },{ min: 6, max: 15, message: '長度在 6 到 15 個字符', trigger: 'blur' }]
}
methods: {async handleLogin (formName) {this.$refs[formName].validate((valid) => {if (valid) {alert('submit!')} else {console.log('error submit!!')return false}})},resetForm (formName) {this.$refs[formName].resetFields()}
}

4.添加鍵盤按下事件,實現回車登錄

問題一:當配置在el-input里,項目無法實現該效果
 <el-input v-model="formdata.password" @keyup.enter="handleLogin('formdata')"></el-input>

解決:
當我們在使用第三方庫時,我們必須在@keyup.enter后面加一個native 來確保這個功能能夠得到實現。

@keyup.enter.native="handleLogin('formdata')"
問題二:在鍵入輸入框后,enter才有效果

解決:
應當全局監聽enter鍵,把監聽事件綁定到document上,而不是在input/button上

  created () {let that = thisdocument.onkeydown = function (e) {e = window.event || eif ((that.$route.path === '/login') && (e.keyCode === 13)) {// 驗證在登錄界面和按得鍵是回車鍵enterthat.handleLogin('formdata')// 登錄函數}}
}

5.修改前后效果對比:

修改前:
login組件修改前效果
修改后:
在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/251424.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/251424.shtml
英文地址,請注明出處:http://en.pswp.cn/news/251424.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

es6 --- set實現并集(Union)、交集(Intersect)和差集(Difference)

Set:類似于數組,但是成員的值都是唯一的 let a new Set([1, 2, 3]); let b new Set([4, 3, 2]);// 并集 let union new Set([...a, ...b]);// 交集 let intersect new Set([...a].filter(x > b.has(x)));// 差級 let difference new Set( [...a].filter(x > !b.has…

解析DBF文件

上周&#xff0c;公司給了許多DBF后綴的數據文件讓我進行解析。 因為是DBF文件我發現mysql&#xff0c;和Oracle都能直接對DBF文件進行導入。在導入過程中發現這些數據庫并不能識別這些文件。 通過百度找到了打開這種文件的軟件Visual FoxPro、Access&#xff0c;用它們打開后出…

Scrum 沖刺 第一日

Scrum 沖刺 第一日 站立式會議燃盡圖Alpha 階段認領任務明日任務安排項目預期任務量成員貢獻值計算規則今日貢獻量參考資料站立式會議 返回目錄 燃盡圖 返回目錄 Alpha 階段認領任務 學號組員分工用時20162309邢天岳補充說明書&部分測試18h20162311張之睿編寫代碼20h201623…

淺析 NodeJs 的幾種文件路徑

Node 中的文件路徑大概有 __dirname, __filename, process.cwd(), ./ 或者 ../&#xff0c;前三個都是絕對路徑&#xff0c;為了便于比較&#xff0c;./ 和 ../ 我們通過 path.resolve(./)來轉換為絕對路徑。 先看一個簡單的栗子&#xff1a; 假如我們有這樣的文件結構&#xf…

Vue項目代碼改進(二)—— element-UI的消息顯示時間修改

Message 消息提示 Options duration 顯示時間, 毫秒。設為 0 則不會自動關閉 — 默認值3000 全局重寫 element 的message 消息提示,修改時間&#xff0c;在main.js里 Vue.prototype.$message function (msg) {ElementUI.Message(msg) } Vue.prototype.$message.success func…

es6 --- 使用node的memoryUsage檢測WeakMap()

打開node命令行 $ node --expose-gc// --expose-gc:表示允許手動執行垃圾回收機制// 手動執行一次垃圾回收,保證獲取的內存使用狀態準確 > global.gc();// 查看內存占用的初始狀態, > process.memoryUsage();可以發現初始用了4.7MB左右 // 創建一個WeakMap()實例wm >…

遍歷字典

Python支持對字典的遍歷&#xff0c;有多種遍歷字典的方式&#xff1a;所有的鍵值對&#xff0c;鍵或者值。 遍歷所有的鍵值對&#xff1a; people {name:winter, age:25, sex:man, }for key,value in people.items():print("\nkey:"key)print("value…

Flexbox 布局

Flexbox 是 flexible box 的簡稱&#xff08;愚人碼頭注&#xff1a;意思是“靈活的盒子容器”&#xff09;&#xff0c;是 CSS3 引入的新的布局模式。它決定了元素如何在頁面上排列&#xff0c;使它們能在不同的屏幕尺寸和設備下可預測地展現出來。 它之所以被稱為 Flexbox &a…

利用jQuery和bootstrap更改radio樣式

<div class"container body-content"><div class"row"><div class"text-center col-xs-12"><h3>標題</h3><div class"well well-sm"><div class"btn-group" data-toggle"butto…

將markdown編譯為HTML和PDF

使用gulp搭建markdown編譯環境 1. 執行npm init 進行項目初始化得到package.json 2. 全局安裝gulp &#xff1a;npm install gulp --global; 3. 在項目中安裝gulp依賴&#xff1a;npm install gulp --save-dev; 4. 創建gulpfile.js文件設置任務&#xff1a; var gulp require…

捕獲異常的兩種方式

捕獲異常的兩種方式方法一 #codingutf-8 import systry:with open("ddd.txt", "r") as f:data f.read()print data except:err sys.exc_info()print errsys.exc_info()返回三元組&#xff0c;分別是&#xff0c;異常類型、異常值、異常追溯地址方法二 #c…

Vue項目代碼改進(三)—— Cookie、LocalStorage和SessionStorage的使用

存在問題&#xff1a; 如果在退出頁面時&#xff0c;沒有點擊“退出”按鈕&#xff0c;而是直接關閉頁面&#xff0c;token并沒有被清除&#xff0c;依然能通過訪問http://localhost:8080/#/ 直接進入主頁。 原因&#xff1a; 使用了localStorage而非sessionStorage或Cookie 一…

es6 --- Proxy實例的get方法

寫一個攔截函數,訪問目標對象不存在屬性時,會拋出不存在該屬性的錯誤 如果存在該屬性時,就返回其值. var person {name: "張三" };var proxy new Proxy(person, {get: function(target, property) {if (property in target) {return target[property];} else {thr…

webstorm前端常用快捷鍵

Ctrl / 行注釋/取消行注釋 Ctrl Shift / 塊注釋/取消塊注釋 Ctrl W 選擇代碼塊&#xff0c;一般是增量選擇 Ctrl Shift W 上個快捷鍵的回退&#xff0c;減量選擇代碼 Alt Q 上下文信息 A…

sql常識

1.UNION與UNION ALL的區別UNION去重且排序UNION ALL不去重不排序2.sql語句or與union all的執行效率比較:union all>union> in >or 用一張表更新另一張表&#xff1a; UPDATE ASET A1 B1, A2 B2, A3 B3FROM A LEFT JOIN B ON A.ID B.IDMS SQL SERVER的寫法&#xf…

優秀導航網站收集

一納米學習網站導航 泡面吧導航 納威安全導航 設計師導航網址 優設圖書導航 極客導航 大前端網址導航 前端導航 轉載于:https://www.cnblogs.com/fazero/p/7976684.html

Vue項目代碼改進(四)—— 在使用ElementUI時點擊同一個路由,頁面報錯

這個不可描述的問題是&#xff1a;在使用ElementUI時點擊同一個路由&#xff0c;頁面報錯。 錯誤代碼如下&#xff1a; element-ui.common.js?ccbf:3339 NavigationDuplicated {_ name: "NavigationDuplicated", name: "NavigationDuplicated", message…

es6 --- Proxy的屬性(get、set除外)

apply()&#xff1a; 攔截函數的調用、call和apply操作 var target function () { return I am the target;}; var handler {apply: function () {reuturn I am the proxy;} };var p new Proxy(target, handler); p(); // " I am the proxy"has(): 判斷對象是否…

關于jQuery對象(類數組對象)以及DOM對象相互轉化問題——[object Object]和[object HTMLInputElement]

之前在某官網課程上看有關jQuery和bootstrap的相關教程&#xff0c;有一節課是教我們如何制作價格菜單的按鈕以及總價問題 選中按鈕&#xff0c;按鈕樣式會發生變化&#xff0c;右上角價格會自動運算 6個菜單的html結構差不多&#xff0c;先貼出一個菜單的html&#xff0c;如下…

如何去掉bootstrap table中表格樣式中橫線豎線

修改之前&#xff0c;表格看上去比較擁擠&#xff0c;因為bootstrap table插件中自帶斑馬線表格樣式&#xff0c;有橫線和豎線分欄&#xff0c;現在我們不需要這些。應UI設計的要求&#xff0c;要去掉中間的橫線和豎線&#xff0c;使用了修改需求中一種簡單粗暴的修改方法&…