javascript - 从表单收集数据,堆叠在对象中并使用 Vue 通过 AJAX 发送

标签 javascript jquery vue.js vuejs2 vue-component

尝试从我的表单中收集所有 HTML 数据,然后将其存储为一个对象,然后使用 ajax 请求发送它。有什么想法吗?感谢一些帮助。我正在尝试使用 serialize 的 jquery,但是无法使用 ajax(post) 以这种方式阅读此内容(发送到 API URL,没有 PHP)。

    <form class="form" action="" method="" id="createProposal">
        <div class="form-group">
            <label class="col-md-12 control-label" for="asset-drop">Asset</label>
            <div class="col-md-12">
                <select id="asset-drop" name="asset-drop" class="form-control" >
                                    <option value="1"> {{ this.assets[0] ? this.assets[0].name : '' }} </option>
                                    <option value="2">{{ this.assets[1] ? this.assets[1].name : '' }}</option>
                                    <option value="3">{{ this.assets[2] ? this.assets[2].name : '' }}</option>
                </select>
            </div>
        </div>
        <div class="form-group">
            <label class="col-md-12 control-label" for="amount-invest">Amount</label>
            <div class="col-md-12">
                <input id="amount-invest" name="amount-invest" type="text" placeholder="Currency" class="form-control input-md">
            </div>
        </div>

        <div class="form-group">
            <label class="col-md-12 control-label" for="description-input">Description</label>
            <div class="col-md-12">
                <textarea class="form-control" id="description-input" name="description-input"></textarea>
            </div>
        </div>

        <div class="modal-footer">
            <button type="button" class="btn btn-secondary cancel" v-on:click="hideCreatePropolsal">Cancel</button>
            <button type="submit" class="btn btn-primary create" v-on:click="formDataCreation">Create</button>
        </div>
    </form>

最佳答案

我建议在您的数据部分创建一个您称之为proposal 的对象,并使用v-model 将您的表单绑定(bind)到该对象,我使用的是单个文件组件但这没关系,您可以根据自己的情况选择解决方案:

<template>
    <form class="form" action="" method="" id="createProposal">
        <div class="form-group">
            <label class="col-md-12 control-label" for="asset-drop">Asset</label>
            <div class="col-md-12">
                <select id="asset-drop" name="asset-drop" class="form-control" v-model="proposal.selectedAsset" >
                                    <option :value="index" :key="index" v-for="(asset,index) in proposal.assets">{{asset}}  </option>
                                  
                </select>
            </div>
        </div>
        <div class="form-group">
            <label class="col-md-12 control-label" for="amount-invest">Amount</label>
            <div class="col-md-12">
                <input id="amount-invest" v-model="proposal.amount" name="amount-invest" type="text" placeholder="Currency" class="form-control input-md">
            </div>
        </div>

        <div class="form-group">
            <label class="col-md-12 control-label" for="description-input">Description</label>
            <div class="col-md-12">
                <textarea class="form-control"  v-model="proposal.description" id="description-input" name="description-input"></textarea>
            </div>
        </div>

        <div class="modal-footer">
            <button type="button" class="btn btn-secondary cancel" v-on:click="hideCreatePropolsal">Cancel</button>
            <button type="submit" class="btn btn-primary create" v-on:click="formDataCreation">Create</button>
        </div>
    </form>
</template>

<script>
export default {
  data(){
    return{
      proposal:{
        assets:[],
        selectedAsset:'',
        amount:'',
        description:''
      }
    }
  },
  methods:{
    hideCreatePropolsal(){

    },
    formDataCreation(){
      /*   $.ajax({
                url: "yourUrl",
                type: "POST",
                data:this.proposal,
                success: function (response) {
                 
                }});*/
    }
  }
};
</script>

<style>
</style>

你可以检查 whole code

关于javascript - 从表单收集数据,堆叠在对象中并使用 Vue 通过 AJAX 发送,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52186416/

相关文章:

jQuery Load 函数不加载 URL 结果?

vue.js - Microsoft EDGE XMLHttpRequest : Network Error 0x80070005, VueJS 拒绝访问

javascript - 如何将事件处理程序附加到 native Node.js 模块中的进程导出?

javascript - 我可以让 jQuery 指向 XML 文档而不是 DOM 吗?

javascript - 使用 Connect 将 Facebook iOS SDK 与评论集成

php - 如果发送/接收 jQuery AJAX 数据,是否可以只接收部分数据?

javascript - Vue.js v-if 不重新渲染

javascript - 如何使用 sentry v5 全局忽略错误以减少噪音

javascript - 上传前检测文件大小: NOT html5

连接到 MVC Controller 时 JavaScript POST 失败