勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

ajaxを使わずに非同期っぽくsubmitする

   2024/01/12  HTML

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('');

とかで取って処理の分岐が行える。

 - HTML

  関連記事

lazyload.js等のライブラリを使わずHTMLのみで画像の遅延読み込みを行う方法

画像を遅延読み込みさせるとなるとだいぶ前に書いたlazyload.jsを用いる方 ...

FileReader APIを用いて画像をアップロードせずにサムネイル表示

以前にFile APIを用いてファイル名やサイズ、形式(拡張子)を取得するメモを ...

formのinput="file"でディレクトリを選択させ、ディレクトリ内のファイルを全てアップロードする方法

フォームで複数のファイルをアップロードしたい場合、input="file"を複数 ...

スマホでフォームの画像アップロード部分でカメラを起動させる方法

formの画像アップロード部分で、スマホの場合にカメラで撮影させたい。以下に対応 ...