前端代码

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>添加商品</title>
</head>
<body>
<form>
<!-- <p><label for="">选择分类</label><input type="text" name="typeid" id="typeid" ></p> -->
<p>
<select name="typeid" id="">
<option value="1">手机</option>
<option value="2">笔记本</option>
</select>
</p>
<p><label for="">商品名称</label><input type="text" name="name"></p>
<p><label for="">价格</label><input type="text" name="price"></p>
<p><label for="">库存</label><input type="text" name="stock"></p>
<p><label for="">图片</label><input type="file" name="img"></p>
<p><textarea name="desc" id="" cols="30" rows="10"></textarea></p>
<button>提交</button>
</form>
</body>
<script src="../../lib/jquery/dist/jquery.min.js"></script>
<script src="../Include/js/add.js"></script>
<script> $('form').submit(function (e) {
var formData = new FormData(this);
$.ajax({
url:"../Controller/add.php",
type:"post",
data:formData,
processData:false,
contentType:false,
success:function(res){
console.log(res);
}
})
e.preventDefault(); })
</script>
</html>

后端代码

// var formData = new FormData(this);
// 把 formData 传给后端, 数据和文件都是通过表单标签的 name 属性值获取 // 1. 接收表单文本数据
/// $typeid = $_POST['typeid'];
// 2. 接收文件
// $_FILES['img'] <?php // 数据库连接信息
header("content-type:text/html; charset=utf-8");
$servername = "localhost";
$username = "root";
$password = "123456";
$dbname = "emall"; // 1. 获取表单传来的数据
$typeid = $_POST['typeid'];
$name = $_POST['name'];
$price = $_POST['price'];
$stock = $_POST['stock'];
$desc = $_POST['desc']; // 2. 上传图片
// 文件前缀
$prefix = 'goods_'; // 获取文件后缀
$temp = explode('.', $_FILES['img']['name']); // 切割字符串
$suffix = end($temp); // 返回数组最后一个元素 // 文件名
$img = $prefix . uniqid().'.'.$suffix;
// 移动文件
move_uploaded_file($_FILES['img']['tmp_name'],'../../public/images/goods/'. $img); $arr = ['typeid' => $typeid,'name' => $name, 'price' => $price,'stock' => $stock, 'img' => $img,'desc'=>$desc];
print_r(json_encode($arr)); // 3. 把数据上传到数据库 // 3.1 连接数据库
$link = mysqli_connect('localhost', 'root', '123456', 'mall'); // 3.2 操作
$sqlInsert = "INSERT INTO `goods` VALUES(NULL,$typeid, '$name', $price, $stock, '$img','$desc')";
// 解决插入数据中文乱码
mysqli_query($link, "set names utf8");
$res = mysqli_query($link, $sqlInsert);
if($res){
echo "成功";
} else {
echo "失败";
}

ajax上传文件,通过FromData把数据传给后端的更多相关文章

  1. IE8/9 JQuery.Ajax 上传文件无效

    IE8/9 JQuery.Ajax 上传文件有两个限制: 使用 JQuery.Ajax 无法上传文件(因为无法使用 FormData,FormData 是 HTML5 的一个特性,IE8/9 不支持) ...

  2. springMVC+jsp+ajax上传文件

    工作中遇到的小问题,做个笔记 实现springMVC + jsp + ajax 上传文件 HTML <body> <form id="myform" method ...

  3. Ajax上传文件进度条显示

    要实现进度条的显示,就要知道两个参数,上传的大小和总文件的大小 html5提供了一个上传过程事件,在上传过程中不断触发,然后用已上传的大 小/总大小,计算上传的百分比,然后用这个百分比控制div框的显 ...

  4. 伪ajax上传文件

    伪ajax上传文件   最近在折腾伪ajax异步上传文件. 网上搜索了一下,发现大部分方法的input file控件都局限于form中,如果是在form外的呢? 必须动态生成一个临时form和临时if ...

  5. flask jQuery ajax 上传文件

    1.html 代码 <div> <form id="uploadForm" enctype="multipart/form-data" > ...

  6. ajax上传文件显示进度

    下面要做一个ajax上传文件显示进度的操作,文末有演示地址 这里先上代码: 1.前端代码 upload.html <!DOCTYPE html> <html lang="e ...

  7. 闲话ajax,例ajax轮询,ajax上传文件[开发篇]

    引语:ajax这门技术早已见怪不怪了,我本人也只是就自己真实的经验去总结一些不足道的话.供不是特别了解的朋友参考参考! 本来早就想写一篇关于ajax的文章的,但是前段时间一直很忙,就搁置了,趁着元旦放 ...

  8. ajax上传文件及进度显示

    之前在博文:原生ajax写法就提及过ajax2.0与1.0的差别是多了FormData和利用FormData文件上传(当然还有跨域,但不是本文的重点). 那么具体怎么样实现ajax上传文件呢? 一般来 ...

  9. django 基于form表单上传文件和基于ajax上传文件

    一.基于form表单上传文件 1.html里是有一个input type="file" 和 ‘submit’的标签 2.vies.py def fileupload(request ...

  10. Ajax 上传文件(input file FormData)

    FormData对象用以将数据编译成键值对,以便用XMLHttpRequest来发送数据.其主要用于发送表单数据,但亦可用于发送带键数据(keyed data),而独立于表单使用. jQuery Aj ...

随机推荐

  1. python中coding:utf-8的作用

    或者

  2. 接口测试-chap4-关联接口测试

    关联接口测试指:请求第2个接口之前必须先请求第一个接口 1.请求第2个接口时需要带着第一个请求返回的cookie 2.如果不使用cookie,如何进行关联接口测试:使用session保持连接.可以代替 ...

  3. 吴裕雄--天生自然python学习笔记:Python3 迭代器与生成器

    迭代器 迭代是Python最强大的功能之一,是访问集合元素的一种方式. 迭代器是一个可以记住遍历的位置的对象. 迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退 ...

  4. 很全很全的 JavaScript 模块讲解

    模块通常是指编程语言所提供的代码组织机制,利用此机制可将程序拆解为独立且通用的代码单元.所谓模块化主要是解决代码分割.作用域隔离.模块之间的依赖管理以及发布到生产环境时的自动化打包与处理等多个方面. ...

  5. unittest(22)- p2p项目实战(4)-read_config

    # 4. read_config.py import configparser class ReadConfig: @staticmethod def get_config(file_path, se ...

  6. module in JavaScript

    JavaScript 在ES6之前没有给出官方模块的定义,因此社区自己搞了两个模块加载方案: CommonJS (node) AMD (browser) 本文略 CommonJS规范 module定义 ...

  7. 学习HEXO的历程

    前言: 简介 开始搭建 命令 API测试 逛github相关的帖子时,发现了hexo.正好想要做一个个人的博客,用来记录自己的各类感悟,所以花一些时间学习学习,以后博客可以放github,省得去注册c ...

  8. JS实现总价随数量变化而变化(顾客购买商品表单)

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:test.html * 作者:常轩 * 微信公众号:Worldh ...

  9. 在idea下遇到的问题汇总(间接性更新)

    在idea下遇到的问题汇总(间接性更新) tomcat下的jsp代码问题: 在idea的环境下,遇到jsp代码.符号失效,首先需要考虑到jar包没有引入,情况如图: 这种情况是因为jar包没有导入进去 ...

  10. SVG 新手入门

    svg 入门新认知 一.第一步创建设置svg <svg width="100%" height="500"> </svg> 设置粗细 5 ...