Commit 22bd899a authored by baiyaaaaa's avatar baiyaaaaa

update form

parent 37ebca5b
This diff is collapsed.
...@@ -7,16 +7,13 @@ ...@@ -7,16 +7,13 @@
mixins: [emitter], mixins: [emitter],
props: { props: {
value: { value: {}
default: '',
required: true
}
}, },
watch: { watch: {
value(value) { value(value) {
this.$emit('change', value); this.$emit('change', value);
this.dispatch('form-item', 'el.form.change', value); this.dispatch('form-item', 'el.form.change', [value]);
} }
} }
}; };
......
...@@ -12,6 +12,6 @@ ...@@ -12,6 +12,6 @@
"author": "haiping.zeng<haiping.zeng@ele.me>", "author": "haiping.zeng<haiping.zeng@ele.me>",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"async-validator": "^1.6.3" "async-validator": "^1.6.5"
} }
} }
...@@ -2,14 +2,16 @@ ...@@ -2,14 +2,16 @@
<div class="el-form-item" :class="{ <div class="el-form-item" :class="{
'is-error': error !== '', 'is-error': error !== '',
'is-validating': validating, 'is-validating': validating,
'is-required': required 'is-required': isRequired || required
}"> }">
<label class="el-form-item__label" v-bind:style="labelStyle" v-if="label"> <label class="el-form-item__label" v-bind:style="labelStyle" v-if="label">
{{label + form.labelSuffix}} {{label + form.labelSuffix}}
</label> </label>
<div class="el-form-item__content" v-bind:style="contentStyle"> <div class="el-form-item__content" v-bind:style="contentStyle">
<slot></slot> <slot></slot>
<div class="el-form-item__error" v-if="error !== ''" transition="md-fade-bottom">{{error}}</div> <transition name="md-fade-bottom">
<div class="el-form-item__error" v-if="error !== ''">{{error}}</div>
</transition>
</div> </div>
</div> </div>
</template> </template>
...@@ -50,24 +52,23 @@ ...@@ -50,24 +52,23 @@
}, },
form() { form() {
var parent = this.$parent; var parent = this.$parent;
while (parent.$el.tagName !== 'FORM') { while (parent.$options.componentName !== 'form') {
parent = parent.$parent; parent = parent.$parent;
} }
return parent; return parent;
}, },
fieldValue() { fieldValue: {
var model = this.form.model; cache: false,
if (!model) { return; } get() {
var model = this.form.model;
if (!model[this.prop]) { if (!model || !this.prop) { return; }
let temp = this.prop.split(':');
return model[temp[0]][temp[1]]; var temp = this.prop.split(':');
} else {
return model[this.prop]; return temp.length > 1
? model[temp[0]][temp[1]]
: model[this.prop];
} }
},
fieldRule() {
return this.rules || (this.form.rules ? this.form.rules[this.prop] : null);
} }
}, },
data() { data() {
...@@ -76,7 +77,8 @@ ...@@ -76,7 +77,8 @@
error: '', error: '',
validateDisabled: false, validateDisabled: false,
validating: false, validating: false,
validator: {} validator: {},
isRequired: false
}; };
}, },
methods: { methods: {
...@@ -98,7 +100,7 @@ ...@@ -98,7 +100,7 @@
model[this.prop] = this.fieldValue; model[this.prop] = this.fieldValue;
validator.validate(model, { first: true, firstFields: true }, (errors, fields) => { validator.validate(model, { firstFields: true }, (errors, fields) => {
this.valid = !errors; this.valid = !errors;
this.error = errors ? errors[0].message : ''; this.error = errors ? errors[0].message : '';
...@@ -111,7 +113,7 @@ ...@@ -111,7 +113,7 @@
this.error = ''; this.error = '';
let model = this.form.model; let model = this.form.model;
let value = model[this.prop]; let value = this.fieldValue;
if (Array.isArray(value) && value.length > 0) { if (Array.isArray(value) && value.length > 0) {
this.validateDisabled = true; this.validateDisabled = true;
...@@ -124,60 +126,49 @@ ...@@ -124,60 +126,49 @@
model[this.prop] = 0; model[this.prop] = 0;
} }
}, },
getRules() {
if (!this.prop) { return []; }
var rules = this.rules || (this.form.rules ? this.form.rules[this.prop] : []);
return Array.isArray(rules) ? rules : [rules];
},
getFilteredRule(trigger) { getFilteredRule(trigger) {
var rules = this.fieldRule; var rules = this.getRules();
if (!rules) { return null; }
if (!trigger) { return rules; }
if (Array.isArray(rules)) {
return rules.filter(rule => {
return !rule.trigger || rule.trigger.indexOf(trigger) !== -1;
});
}
if (rules.trigger && rules.trigger.indexOf(trigger) === -1) { return rules.filter(rule => {
return null; return !rule.trigger || rule.trigger.indexOf(trigger) !== -1;
} else { });
return rules; },
} onFieldBlur() {
}
},
ready() {
var rules = this.fieldRule;
if (rules) {
if (Array.isArray(rules)) {
rules.every(rule => {
if (rule.required) {
this.required = true;
return false;
}
});
} else {
this.required = !!this.rules.required;
}
}
if (this.prop) {
this.dispatch('form', 'el.form.addField', this);
}
},
events: {
'el.form.blur'(value) {
this.validate('blur'); this.validate('blur');
}, },
'el.form.change'(value, useTrigger = true) { onFieldChange() {
if (this.validateDisabled) { if (this.validateDisabled) {
this.validateDisabled = false; this.validateDisabled = false;
return; return;
} }
var trigger = useTrigger ? 'change' : ''; this.validate('change');
this.validate(trigger); }
},
mounted() {
var rules = this.getRules();
rules.every(rule => {
if (rule.required) {
this.isRequired = true;
return false;
}
});
if (this.prop) {
this.dispatch('form', 'el.form.addField', [this]);
} }
this.$on('el.form.blur', this.onFieldBlur);
this.$on('el.form.change', this.onFieldChange);
}, },
beforeDestroy() { beforeDestroy() {
this.dispatch('form', 'el.form.removeField', this); this.dispatch('form', 'el.form.removeField', [this]);
} }
}; };
</script> </script>
...@@ -7,8 +7,6 @@ ...@@ -7,8 +7,6 @@
</form> </form>
</template> </template>
<script> <script>
import AsyncValidator from 'async-validator';
export default { export default {
name: 'ElForm', name: 'ElForm',
...@@ -28,27 +26,21 @@ ...@@ -28,27 +26,21 @@
data() { data() {
return { return {
fields: {}, fields: {},
fieldLength: 0, fieldLength: 0
validator: {}
}; };
}, },
ready() { created() {
if (this.rules) { this.$on('el.form.addField', (field) => {
this.validator = new AsyncValidator(this.rules);
}
},
events: {
'el.form.addField'(field) {
this.fields[field.prop] = field; this.fields[field.prop] = field;
this.fieldLength++; this.fieldLength++;
}, });
'el.form.removeField'(field) { this.$on('el.form.removeField', (field) => {
delete this.fields[field.prop]; delete this.fields[field.prop];
this.fieldLength--; this.fieldLength--;
} });
}, },
methods: { methods: {
resetForm() { resetFields() {
for (let prop in this.fields) { for (let prop in this.fields) {
let field = this.fields[prop]; let field = this.fields[prop];
field.resetField(); field.resetField();
......
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
> >
</template> </template>
<!-- 写成垂直的方式会导致 placeholder 失效, 蜜汁bug --> <!-- 写成垂直的方式会导致 placeholder 失效, 蜜汁bug -->
<textarea v-else v-model="currentValue" class="el-textarea__inner" :name="name" :placeholder="placeholder" :disabled="disabled" :readonly="readonly" @focus="$emit('onfocus', val)" @blur="handleBlur"></textarea> <textarea v-else v-model="currentValue" class="el-textarea__inner" :name="name" :placeholder="placeholder" :disabled="disabled" :readonly="readonly" @focus="$emit('onfocus', currentValue)" @blur="handleBlur"></textarea>
</div> </div>
</template> </template>
<script> <script>
...@@ -37,7 +37,7 @@ ...@@ -37,7 +37,7 @@
mixins: [emitter], mixins: [emitter],
props: { props: {
value: {}, value: [String, Number],
placeholder: { placeholder: {
type: String, type: String,
default: '' default: ''
...@@ -116,7 +116,7 @@ ...@@ -116,7 +116,7 @@
'currentValue'(val) { 'currentValue'(val) {
this.$emit('input', val); this.$emit('input', val);
this.$emit('onchange', val); this.$emit('onchange', val);
this.dispatch('form-item', 'el.form.change', val); this.dispatch('form-item', 'el.form.change', [val]);
} }
} }
}; };
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment