ajaxを使わずに非同期っぽくsubmitする
2024/01/12
ajaxを使わずに見た目はページ遷移せず、
画像を含めたformをsubmitしているソースがあり、
なるほどと思ったのでメモ。
■index.php(formを置いているところ)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transtional//EN" "http://www.w3c.org/TR/html4/loose.dtd">
<meta http-equiv="content-type" content="text/html"/>
<meta cherset = "UTF-8">
<html lang="ja">
<head>
<title>index</title>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script>
$(function(){
$(document).on('click', '#submitBtn', function(){
if ($('#name').val() != '') {
$('#postForm').submit();
}
});
});
</script>
</head>
<body>
<h1>index</h1>
<form action="receive.php" target="submitTarget" method="post" name="postForm" id="postForm">
<input type="text" name="name" id="name">
<input type="button" value="submit" id="submitBtn">
</form>
<iframe scr="iframe.php" width="1" height="1" id="submitTarget" name="submitTarget" style="opacity:0;"></iframe>
</body>
</html>
■iframe.php
<!--ソースは空でOK-->
■recieve.php
<?php
$mysqli = new mysqli($dbhost, $dbuser, $dbpass, $dbname);
$mysqli->set_charset('utf8');
if ($_POST['name']) {
$sql = '
INSERT INTO form
(name)
VALUES
("'. $mysqli->real_escape_string($_POST['name']) .'")
';
$row = $mysqli->query($sql);
echo (!$row) ? 'false' : 'true';
}
?>
■その他
formをiframe対して投げているっぽい。
結果のtrue or falseについてはiframeのbody内に
表示されるから、
$('#submitTarget').contents().find('body').html('');
とかで取って処理の分岐が行える。
関連記事
-
スマホでフォームの画像アップロード部分でカメラを起動させる方法
formの画像アップロード部分で、スマホの場合にカメラで撮影させたい。以下に対応 ...
-
formのinput="file"でディレクトリを選択させ、ディレクトリ内のファイルを全てアップロードする方法
フォームで複数のファイルをアップロードしたい場合、input="file"を複数 ...
-
FileReader APIを用いて画像をアップロードせずにサムネイル表示
以前にFile APIを用いてファイル名やサイズ、形式(拡張子)を取得するメモを ...
-
ブラウザがWebP対応の場合はそのまま表示し、非対応の場合はjpg/png画像を表示させる方法
ページ表示時にブラウザがWebP画像に対応している場合はそのまま表示し、非対応の ...
-
lazyload.js等のライブラリを使わずHTMLのみで画像の遅延読み込みを行う方法
画像を遅延読み込みさせるとなるとだいぶ前に書いたlazyload.jsを用いる方 ...