Так что у меня проблема. Я пытаюсь вставить в базу данных сообщения, сделанные пользователями, и я хотел бы использовать Ajax, чтобы сделать его более динамичным и посылать входные данные, выбирать значения и контент в div с возможностью редактирования контента через jQuery. Я использую FormData, чтобы получить все данные в форме.
У меня есть эта форма:
<form id="data" method="post" enctype="multipart/form-data">
<input type="text" name="title" placeholder="Title">
<div id="content" class="content" contenteditable="true"></div>
<input type="text" name="tags" placeholder="Tags">
<input type="file" name="file">
<select>
<option value="0">Select...</option>
<option value="1">Option A</option>
<option value="2">Option B</option>
<option value="3">Option C</option>
</select>
<button name="insert" value="insert" class="button">Post</button></form>
JQuery / Ajax:
$(document).ready(function(){
$("form#data").submit(function(){
var formData = new FormData($(this)[0]);
var cont = $("#content").val();
formData.append("content", cont);
$.ajax({
url: 'iproddone.php',
type: 'POST',
data: formData,
async: false,
success: function (data) {
alert(data);
location.reload();
},
cache: false,
contentType: false,
processData: false
});
return false;
});
});
Я недавно добавил строку var cont = $("#content").val();
а также formData.append("content", cont);
и я заметил, что php больше не помечает ошибку при попытке $_POST['content'];
но когда у меня не было тех строк, php помечал ошибку.
PHP:
<?php
if (isset($_POST['insert'])) {
include_once('conn.php'); //connection file
$tt=$_POST['title'];
$cont=$_POST['content'];
$tags=$_POST['tags'];
$foo = $tt;
$foo = ucfirst($foo);
if ( 0 < $_FILES['file']['error'] ) {
echo 'Error: ' . $_FILES['file']['error'] . '<br>';
}
else {
move_uploaded_file($_FILES['file']['tmp_name'], 'img/tmb_prod/' . $_FILES['file']['name']);
$photo=$_FILES['file']['name'];
}
echo "Image uploaded";
$connn=mysql_connect("localhost","root","")or die("Connection problems");
mysql_select_db("gtcomputer",$conn)or die("Error");
mysql_query("insert into posts(title,content,tags,photo)values('$foo','$cont','$tags','$photo')",$conn)or die("Error".mysql_error());
}
else{
header('Location: index.php');
}
?>
Когда я делаю новое сообщение, в таблицу сообщений вставляются только заголовок, теги и имя файла.
Только что добавлен formData.append('content', $('#content').html());
и работал.
$(document).ready(function(){
$("form#data").submit(function(){
var formData = new FormData($(this)[0]);
formData.append('content', $('#content').html());
$.ajax({
url: 'iproddone.php',
type: 'POST',
data: formData,
async: false,
success: function (data) {
alert(data);
location.reload();
},
cache: false,
contentType: false,
processData: false
});
return false;
});
});
Других решений пока нет …