勉強したことのメモ

webプログラマ見習いが勉強したことのメモ。

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

      2014/05/19

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, 画像

  関連記事

images
PHPでコマンドを実行して画像を加工

PHPで画像をリサイズしたりサムネイルを作ろうとすると、 ソースが長くなって面倒 ...

jquery_logo
jQueryで画像を遅延ロードする(jquery.lazyload.js)

画像を遅延ロードさせたい時にはlazyloadが便利。 ■ダウンロード http ...

jquery_logo
jquery.snipeの使い方

使い方によっては面白くなりそう。 ■jquery.snipe http://ra ...

images
登録画像orノーイメージ画像の振り分け表示

<? /* 画像が登録されていれば当該画像を読み出し、 登録されていない場 ...

jquery_logo
画像をドラッグ&ドロップでアップロード

■2015/04/15追記 以下記事の方が新しくて詳しい。 http://tai ...

images
PHPで画像にモザイクをかけて保存

やりたかった事はPHPで ・モザイク処理 ・元の画像とは別にファイル名をつけて保 ...

110126-HTML5_Logo
html内に動画を埋め込んで配信する方法

Webページ内にYoutubeとかを用いずに、動画ファイルを配信したいというケー ...

images
画像削除用function

ファイルパス、拡張子、seq番号、画像番号を渡してあげるだけ。 拡張子部分があれ ...

jquery_logo
画像をサムネイル⇔クリックで拡大(lightbox)

画像をサムネイル表示してクリックしたら大きく表示する というのがlightbox ...

images
画像登録用のfunction

<?php /****** 画像アップロード用function 画像送付側 ...