前言
在网上找了一点资料,但是还是觉得不太行,就自己写了一个,与网上的也大差不差,都是用4个输入框和.号组合起来的,主要就是监听输入框事件和键盘按下事件还有光标位置完成的,废话不多说,直接复制就可以用了。
使用方法
1.我已经将这个代码注册为了一个组件,在自己的组件库中创建文件IpModel.vue,将下面的代码复制到组件中。
#IpModel.vue
<template>
<div class="ip-input">
<input id="ip1" v-model="ip1" ref='input1' @input="handleInput(1)" @keydown="handleKeyDown($event, 1)"
maxlength="3" />
<span>.</span>
<input id="ip2" v-model="ip2" ref='input2' @input="handleInput(2)" @keydown="handleKeyDown($event, 2)"
maxlength="3" />
<span>.</span>
<input id="ip3" v-model="ip3" ref='input3' @input="handleInput(3)" @keydown="handleKeyDown($event, 3)"
maxlength="3" />
<span>.</span>
<input id="ip4" v-model="ip4" ref='input4' @input="handleInput(4)" @keydown="handleKeyDown($event, 4)"
maxlength="3" />
</div>
</template>
<script>
export default {
name: "IpModel",
props: {
IP: String,
},
data() {
return {
ip1: "",
ip2: "",
ip3: "",
ip4: "",
};
},
methods: {
handleInput(index) {
this[`ip${index}`] = this[`ip${index}`].replace(/[^0-9]/g, '')
let ip = this[`ip${index}`];
if (ip.length > 1 && ip[0] === "0") {
this[`ip${index}`] = ip.slice(1);
}
if (ip > 255) {
this[`ip${index}`] = "255";
}
if (ip.length === 3 || ip[0] === "0") {
let nextIndex = index + 1;
if (nextIndex <= 4) {
this.$refs[`input${nextIndex}`].focus();
}
}
},
handleKeyDown(event, index) {
let ip = this[`ip${index}`];
if (event.keyCode == 8 && 0 == document.getElementById(`ip${index}`).selectionStart) {
let nextIndex = index - 1;
if (nextIndex >= 1) {
this.$refs[`input${nextIndex}`].focus();
document.getElementById(`ip${nextIndex}`).setSelectionRange(this[`ip${nextIndex}`].length, this[`ip${nextIndex}`].length)
}
} else if (event.keyCode == 46 && ip.length == document.getElementById(`ip${index}`).selectionStart) {
let nextIndex = index + 1;
if (nextIndex <= 4) {
this.$refs[`input${nextIndex}`].focus();
document.getElementById(`ip${nextIndex}`).setSelectionRange(0, 0)
}
}
else if ((event.keyCode == 37) && 0 == document.getElementById(`ip${index}`).selectionStart) {
let nextIndex = index - 1;
if (nextIndex >= 1) {
this.$refs[`input${nextIndex}`].focus();
document.getElementById(`ip${nextIndex}`).setSelectionRange(this[`ip${nextIndex}`].length, this[`ip${nextIndex}`].length)
}
} else if ((event.keyCode == 39) && ip.length == document.getElementById(`ip${index}`).selectionStart) {
let nextIndex = index + 1;
if (nextIndex <= 4) {
this.$refs[`input${nextIndex}`].focus();
document.getElementById(`ip${nextIndex}`).setSelectionRange(0, 0)
}
} else if (event.keyCode == 110 || event.keyCode == 190) {
let nextIndex = index + 1;
if (nextIndex <= 4) {
this.$refs[`input${nextIndex}`].focus();
}
} else {
return false
}
},
IpModelSend() {
if (this.ip1 == '' || this.ip2 == '' || this.ip3 == '' || this.ip4 == '') {
this.$message({
duration: 1000,
message: 'IP地址非法,请输入正确的IP地址!'
});
} else {
const ip = this.ip1 + '.' + this.ip2 + '.' + this.ip3 + '.' + this.ip4
this.$emit('changeIP', ip);
}
},
IpModelCancel() {
this.ip1 = this.IP.split('.')[0]
this.ip2 = this.IP.split('.')[1]
this.ip3 = this.IP.split('.')[2]
this.ip4 = this.IP.split('.')[3]
}
},
};
</script>
<style scoped>
.ip-input {
display: flex;
justify-content: space-between;
align-items: center;
width: 160px;
height: 40px;
border: 1px solid #ccc;
border-radius: 4px;
padding: 0 10px;
box-sizing: border-box;
font-size: 16px;
}
.ip-input input {
width: 30px;
height: 90%;
border: none;
outline: none;
text-align: center;
font-size: 16px;
}
.ip-input span {
font-size: 16px;
}
</style>
2.在需要使用到IP输入框的地方调用组件即可,例如:
<template>
<div>
<button class="ethernet" @click="IPVisible = true">IP输入框</button>
<el-dialog v-model="IPVisible" title="" width="350px" align-center>
<IpModel ref="ipModel" :IP="IP" v-on:changeIP="changeIP"></IpModel>
<template #footer>
<el-button @click="ipModelSure">确认</el-button>
<el-button @click="ipModelCancel">取消</el-button>
</template>
</el-dialog>
</div>
</template>
<script>
import IpModel from '../components/IpModel.vue'
export default {
components: {
IpModel
},
data() {
return {
IPVisible: false,
IP: "127.0.0.1",
}
},
methods: {
ipModelSure() {
this.$refs.ipModel.IpModelSend(); // 调用IpModel子组件的IpModelSend方法
},
ipModelCancel() {
this.IPVisible = false
this.$refs.ipModel.IpModelCancel(); // 调用IpModel子组件的IpModelCancel方法
},
changeIP(value) {
console.log(value)
this.IPVisible = false
},
},
}
</script>
<style scoped></style>
3.当点击确定按钮时,父组件通过this.$refs.ipModel.IpModelSend();去调用子组件的方法,子组件通过this.$emit('changeIP', ip);返回ip值,父组件通过监听事件changeIP调用方法打印出ip
4.当点击取消按钮时,父组件通过this.$refs.ipModel.IpModelCancel();去调用子组件的方法,重新给ip赋值,使数据不产生变化
结束
伍鳴
2023/3/23 发布