美文网首页
vue获取form表单的数据(mpvue小程序转H5 Form表

vue获取form表单的数据(mpvue小程序转H5 Form表

作者: 不二很纯洁 | 来源:发表于2019-04-04 10:41 被阅读0次

    利用表单的 FormData 对象获取

    <template>
        <form report-submit @submit.prevent="submit">
            <input placeholder="搜索内容" name="serch" />
            <button formType="submit">提交表单</button>
        </form>
    </template>
    <script>
    ...
    methods: {
        submit(e){
            const formData = new FormData(e.target);
            const value = {};
            for(let pair of formData.entries()) {
                value[pair[0]] = pair[1];
            }
            console.log(value)
        }
    }
    </script>
    

    先简单记录,完成之后再详细梳理,不知道有没有兼容问题


    2019年7月4日 10:05:59更新:

    之前的有兼容性,翻车车,所以修改如下:

    /**
     * 获取表单内容
     * @param {*} form 
     */
    export const getFormData = form => {
        const res = {}; //存放结果的对象
        
        for(let i=0; i<form.elements.length; i++){
            
            let current = form.elements[i];
            
            //disabled表示字段禁用,需要区分与readonly的区别
            if(current.disabled) continue;
            
            switch(current.type){
                
                //可忽略控件处理
                case "file":    //文件输入类型
                case "submit":  //提交按钮
                case "button":  //一般按钮
                case "image":   //图像形式的提交按钮
                case "reset":   //重置按钮
                case undefined: //未定义
                    break;
                
                //select控件
                case "select-one":
                case "select-multiple":
                    if(current.name && current.name.length){
                        console.log(current)
                        for(let k=0; k<current.options.length; k++){
                            let option = current.options[k];
                            let optionValue = "";
                            if(option.selected){
                                if(option.hasAttribute){
                                    optionValue = option.hasAttribute('value') ? option.value : option.text
                                }else{
                                    //低版本IE需要使用特性 的specified属性,检测是否已规定某个属性
                                    optionValue = option.attributes('value').specified ? option.value : option.text;    
                                }
                                // res[encodeURIComponent(current.name)] = encodeURIComponent(optionValue);
                                res[encodeURIComponent(current.name)] = optionValue;
                            }
                        }
                    }
                    break;
                    
                //单选,复选框
                case "radio":
                case "checkbox":
                    //这里有个取巧 的写法,这里的判断是跟下面的default相互对应。
                    //如果放在其他地方,则需要额外的判断取值
                    if(!current.checked) break;
                
                default:
                    //一般表单控件处理
                    if(current.name && current.name.length){
                        // res[encodeURIComponent(current.name)] = encodeURIComponent(current.value);
                        res[encodeURIComponent(current.name)] = current.value;
                    }
                    break;
            }
        }
        return res;
    }
    
    <template>
        <form report-submit @submit.prevent="submit">
            <input placeholder="搜索内容" name="serch" />
            <button formType="submit">提交表单</button>
        </form>
    </template>
    <script>
    ...
    methods: {
        submit(e){
            const value = util.getFormData(e.target);
            console.log(value)
        }
    }
    </script>
    

    相关文章

      网友评论

          本文标题:vue获取form表单的数据(mpvue小程序转H5 Form表

          本文链接:https://www.haomeiwen.com/subject/khqfiqtx.html