ajax增删改查数据
admin
2023-02-12 16:20:03
0

这篇文章主要为大家详细介绍了使用ajax增删改查数据的方法,文中示例代码介绍的非常详细,零基础也能参考此文章,感兴趣的小伙伴们可以参考一下。

function $(id) {
    //  获取html中所有id
    return document.getElementById(id);
}
let wq_content = $("wq-content"); // 问题
let wq_where = $("wq-where"); // 问题在哪
let wq_idea = $("wq-idea"); // 问题想法
let wq_save_question = $("wq-save-question"); // 提交按钮
let tbody = $("tbody"); // 显示区域
let wq_in = $("in") //  填空区
let add_wq = $("add-wq") // 添加按钮

//  封装提交/修改函数   连个参数1.url   2.id
function aUrl(urls, ids) {
    //  创建变量data存放用户输入内容
    let data = {
        "id": ids,
        "wq_content": wq_content.value,
        "wq_where": wq_where.value,
        "wq_idea": wq_idea.value,
    };

    //  调用ajax发送数据
    ajax1({
        url: urls,
        type: "post",
        data: data,
        fn: function(data) {
            if (data == 1) {
                //  数据保存成功
                location.reload(); // 刷新
            } else {
                alert("数据保存失败,请重试");
            }
        }
    })
}

//  当点击添加按钮时,将提交按钮改为提交,点击提交时执行添加命令
add_wq.onclick = function() {
    wq_save_question.innerHTML = "提交";
    //  提交添加点击事件    
    wq_save_question.onclick = function() {
        //  调用封装函数传参(不用传id)
        aUrl("php/addData.php");
    }
}

//  显示数据        只有显示出数据才能删除和修改
ajax1({
    url: "php/showData.php",
    type: "get",
    fn: function(data) {
        //  字符串格式转换成json格式
        data = JSON.parse(data);

        let str = ""; //    放数据
        let count = ""; //  计数

        //  遍历导入
        data.forEach(item => {
            count++;
            str +=
                `
                
                        ${count}
                        ${item.wq_content}
                        ${item.wq_where}
                        
                            ${item.wq_idea}
                            
                        
                        
                            
                        
                        
                            
                        
                    
            `;
        })
        tbody.innerHTML = str; //上树

        //  修改数据
        //  获取当前点击的是哪个id的修改按钮
        //  取出原值填入框中,进行修改
        //  点击保存,执行修改操作
        let xiugai = document.querySelectorAll(".xiugai"); //   在79行生成按钮时,添加了个类名
        for (let i = 0; i < xiugai.length; i++) {
            xiugai[i].onclick = function() {

                //  获取id
                let id = xiugai[i].getAttribute("data-id");

                //  修改提交按钮为保存   这里有两个目的:1.改按钮名字 2.区分当前弹框是添加功能还是修改功能***
                wq_save_question.innerHTML = "保存";

                //  获取原数据
                let wq_content_old = xiugai[i].parentNode.parentNode.children[1].innerText;
                let wq_where_old = xiugai[i].parentNode.parentNode.children[2].innerText;
                let wq_idea_old = xiugai[i].parentNode.parentNode.children[3].innerText;
                // console.log(wq_content_old )
                // console.log(wq_where_old )
                // console.log(wq_idea_old )

                //  填入原数据   判断为保存说明是修改功能
                if (wq_save_question.innerHTML = "保存") {
                    // 将原数据还原到弹框中
                    wq_content.value = wq_content_old;
                    wq_where.value = wq_where_old;
                    wq_idea.value = wq_idea_old;

                    //  当按钮为保存时,点击保存(执行修改命令)
                    wq_save_question.onclick = function() {
                        //  调用封装函数传参(需要传id)
                        aUrl("php/updataData.php", id);
                        // console.log(id)
                    }
                }
            }
        }

        //  删除数据
        let delBtns = document.querySelectorAll(".delBtn");
        //  循环判断点击的是哪个删除
        for (let i = 0; i < delBtns.length; i++) {
            delBtns[i].onclick = function() {

                //  获取当前按钮的id
                let id = delBtns[i].getAttribute("data-id");
                // console.log(id)

                //  调用ajax执行删除          这里也可以调用封装函数实现
                ajax1({
                    url: "php/delData.php",
                    type: "get",
                    data: {
                        id: id
                    },
                    fn: function(data) {
                        //  移出dom节点
                        if (data = 1) {
                            //  数据库删除成功后,将页面上的节点删除
                            tbody.removeChild(delBtns[i].parentNode.parentNode);
                        } else {
                            alert("删除失败");
                        }
                    }
                })
            }
        }
    }
})

看完上述内容,你们掌握使用ajax增删改查数据的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注行业资讯频道,感谢各位的阅读!


                                                         

相关内容

热门资讯

德国总理:美国正在被伊朗羞辱 德国之声4月27日报道,德国总理默茨在访问一所学校时表示,在当前的持续冲突中,伊朗领导层正试图羞辱美...
理响中国|“长”歌以行,风云激... 光阴如梭,东方潮阔。这里是中国的长三角,世界的长三角。无论过去、现在还是未来,这片土地都因时代而生,...
白宫:特朗普及其国安团队开会讨... 新华社华盛顿4月27日电 美国白宫新闻秘书莱维特27日在记者会上证实,总统特朗普及其国家安全团队当天...
人民日报刊文:日本放开杀伤性武... 日本放开杀伤性武器出口推高地缘冲突风险(国际论坛)常思纯《人民日报》(2026年04月28日 第 0...
医疗保障法草案二审:明确生育保... 满足多样化健康保障需求本报记者 彭 波4月27日,医疗保障法草案二审稿提请十四届全国人大常委会第二十...
天津一景区发生自转旋翼机事故1... 澎湃新闻记者 吕新文中国民用航空华北地区管理局4月22日公布《豪客通航“10•1”天津长芦汉盐旅游区...
卡塔尔埃米尔与美国总统特朗普通... 当地时间24日,卡塔尔埃米尔塔米姆与美国总统特朗普通电话,重点就中东地区局势以及伊朗与美国谈判问题交...
男子30年前被扣押2859克黄... 澎湃新闻记者 王鑫家住辽宁省大连市的潘永嘉近日向澎湃新闻反映称,三十年前,他在大连周水子机场被盖州市...
商务部:取消反制欧盟两家金融机... 中华人民共和国商务部令二〇二六年 第1号鉴于欧盟已取消对中国两家金融机构的制裁措施,现公布《关于取消...
过去24小时共有5艘船只通过霍... 总台记者当地时间24日获悉,过去24小时内,共有5艘船只通过霍尔木兹海峡,其中包括一艘伊朗油轮。(总...