mirror of
				https://github.com/pure-admin/vue-pure-admin.git
				synced 2025-11-03 13:44:47 +08:00 
			
		
		
		
	perf: 优化登录回车事件
This commit is contained in:
		
							parent
							
								
									fc33e7e3f2
								
							
						
					
					
						commit
						b871d8528e
					
				@ -13,7 +13,6 @@ import { message } from "@pureadmin/components";
 | 
				
			|||||||
import type { FormInstance } from "element-plus";
 | 
					import type { FormInstance } from "element-plus";
 | 
				
			||||||
import { storageSession } from "@pureadmin/utils";
 | 
					import { storageSession } from "@pureadmin/utils";
 | 
				
			||||||
import { $t, transformI18n } from "/@/plugins/i18n";
 | 
					import { $t, transformI18n } from "/@/plugins/i18n";
 | 
				
			||||||
import { ref, reactive, watch, computed } from "vue";
 | 
					 | 
				
			||||||
import { operates, thirdParty } from "./utils/enums";
 | 
					import { operates, thirdParty } from "./utils/enums";
 | 
				
			||||||
import { useLayout } from "/@/layout/hooks/useLayout";
 | 
					import { useLayout } from "/@/layout/hooks/useLayout";
 | 
				
			||||||
import { useUserStoreHook } from "/@/store/modules/user";
 | 
					import { useUserStoreHook } from "/@/store/modules/user";
 | 
				
			||||||
@ -22,6 +21,14 @@ import { ReImageVerify } from "/@/components/ReImageVerify";
 | 
				
			|||||||
import { useRenderIcon } from "/@/components/ReIcon/src/hooks";
 | 
					import { useRenderIcon } from "/@/components/ReIcon/src/hooks";
 | 
				
			||||||
import { useTranslationLang } from "/@/layout/hooks/useTranslationLang";
 | 
					import { useTranslationLang } from "/@/layout/hooks/useTranslationLang";
 | 
				
			||||||
import { useDataThemeChange } from "/@/layout/hooks/useDataThemeChange";
 | 
					import { useDataThemeChange } from "/@/layout/hooks/useDataThemeChange";
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  ref,
 | 
				
			||||||
 | 
					  reactive,
 | 
				
			||||||
 | 
					  watch,
 | 
				
			||||||
 | 
					  computed,
 | 
				
			||||||
 | 
					  onMounted,
 | 
				
			||||||
 | 
					  onBeforeUnmount
 | 
				
			||||||
 | 
					} from "vue";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import dayIcon from "/@/assets/svg/day.svg?component";
 | 
					import dayIcon from "/@/assets/svg/day.svg?component";
 | 
				
			||||||
import darkIcon from "/@/assets/svg/dark.svg?component";
 | 
					import darkIcon from "/@/assets/svg/dark.svg?component";
 | 
				
			||||||
@ -85,6 +92,21 @@ watch(imgCode, value => {
 | 
				
			|||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
dataThemeChange();
 | 
					dataThemeChange();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** 使用公共函数,避免`removeEventListener`失效 */
 | 
				
			||||||
 | 
					function onkeypress({ code }: KeyboardEvent) {
 | 
				
			||||||
 | 
					  if (code === "Enter") {
 | 
				
			||||||
 | 
					    onLogin(ruleFormRef.value);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					onMounted(() => {
 | 
				
			||||||
 | 
					  window.document.addEventListener("keypress", onkeypress);
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					onBeforeUnmount(() => {
 | 
				
			||||||
 | 
					  window.document.removeEventListener("keypress", onkeypress);
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
@ -149,7 +171,6 @@ dataThemeChange();
 | 
				
			|||||||
            :model="ruleForm"
 | 
					            :model="ruleForm"
 | 
				
			||||||
            :rules="loginRules"
 | 
					            :rules="loginRules"
 | 
				
			||||||
            size="large"
 | 
					            size="large"
 | 
				
			||||||
            @keyup.enter="onLogin(ruleFormRef)"
 | 
					 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <Motion :delay="100">
 | 
					            <Motion :delay="100">
 | 
				
			||||||
              <el-form-item
 | 
					              <el-form-item
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user