57 lines
1.3 KiB
Vue
57 lines
1.3 KiB
Vue
|
import InputNumber from '../src/index'
|
||
|
import '../assets/index.less'
|
||
|
|
||
|
export default {
|
||
|
data () {
|
||
|
return {
|
||
|
disabled: false,
|
||
|
readOnly: false,
|
||
|
value: 50000,
|
||
|
}
|
||
|
},
|
||
|
methods: {
|
||
|
onChange (value) {
|
||
|
console.log('onChange:', value)
|
||
|
this.value = value
|
||
|
},
|
||
|
toggleDisabled () {
|
||
|
this.disabled = !this.disabled
|
||
|
},
|
||
|
toggleReadOnly () {
|
||
|
this.readOnly = !this.readOnly
|
||
|
},
|
||
|
numberWithCommas (x) {
|
||
|
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',')
|
||
|
},
|
||
|
format (num) {
|
||
|
return `$ ${this.numberWithCommas(num)} boeing737`
|
||
|
},
|
||
|
parser (num) {
|
||
|
return num.toString().split(' ')[1].replace(/,*/g, '')
|
||
|
},
|
||
|
},
|
||
|
render () {
|
||
|
return (
|
||
|
<div style='margin: 10px;'>
|
||
|
<InputNumber
|
||
|
min={-8000}
|
||
|
max={10000000}
|
||
|
value={this.value}
|
||
|
onChange={this.onChange}
|
||
|
style='width: 200px'
|
||
|
readOnly={this.readOnly}
|
||
|
disabled={this.disabled}
|
||
|
autoFocus={false}
|
||
|
step={100}
|
||
|
formatter={this.format}
|
||
|
parser={this.parser}
|
||
|
/>
|
||
|
<p style='padding:10px 0'>
|
||
|
<button onClick={this.toggleDisabled}>toggle Disabled</button>
|
||
|
<button onClick={this.toggleReadOnly}>toggle readOnly</button>
|
||
|
</p>
|
||
|
</div>
|
||
|
)
|
||
|
},
|
||
|
}
|