現在、PHPとBootstrapを使ってWebサイトを作っています。
サイト内に画像アップロード機能を持った「WYSIWYGエディタ」を設置したいと考え、「bootstrap-wysiwyg」というプラグインを見つけたのですが、使い方(入力されたデータの取得方法)がよく分かりません。
http://mindmup.github.io/bootstrap-wysiwyg/
<form>内の1つの要素として「bootstrap-wysiwyg」のエディタを設置し、<textarea>の代わりに使いたいと思うのですが、他の入力項目と同時にPOST送信するにはどのようにすれば良いのでしょうか?
また、挿入された(複数の)画像ファイルは、PHP側でどのように取得・保存すれば良いのでしょうか?
どうぞよろしくお願い致します。
http://mindmup.github.io/bootstrap-wysiwyg/
↑の Usage に書いてあるとおり、
$('#editor').wysiwyg();
とした要素が WYSIWYG なエディタになります。
対象にできる要素は DIV などの contenteditable=true を受け入れる要素です。
入力した内容を POST で送信したければ、対象となった要素の innerHTML を form の内容にぶち込んであげるだけです。
改行も <br> で表現されるので、<input type="hidden"> に入れてあげれば大丈夫ですが、もちろん <textarea> でも大丈夫です。
<textarea> に入れる場合には、POST が完了するまでの一瞬の間、HTML な内容が見えてしまうので、スタイルで見えなくするなり、小さくするなりしておかないと、ちょっと不格好な感じです。
因みに画像は、data URI スキーム で表現されています。
こんな感じ(グリーンスターの画像です)。
<img src="">
対象となった要素の innerHTML の表現の一部として入ってますので、そのまま保存すれば画像も保存されます。
POST する form の onsubmit で #editor の innerHTML を取得して、form 内の要素に入れてあげる感じで良いと思います。
<form onsubmit="return put_editor_data()"> <textarea name="editor_data"></textarea> </form> <script> function put_editor_data() { $("TEXTAREA[name=editor_data]").val($("#editor").html()); return true; } </script>
一つ確認したいことがあります。
このソフトはクライアントのPC上でリッチテキストを作成するソフトであり、作成されたリッチテキストを保存するものではありません。
従って
<form>内の1つの要素として「bootstrap-wysiwyg」のエディタを設置し、<textarea>の代わりに使いたいと思うのですが、他の入力項目と同時にPOST送信するにはどのようにすれば良いのでしょうか? また、挿入された(複数の)画像ファイルは、PHP側でどのように取得・保存すれば良いのでしょうか?
といった機能はないのですが、本質問はjsにPOSTの機能を付けろという意味でしょうか。
http://mindmup.github.io/bootstrap-wysiwyg/
↑の Usage に書いてあるとおり、
$('#editor').wysiwyg();
とした要素が WYSIWYG なエディタになります。
対象にできる要素は DIV などの contenteditable=true を受け入れる要素です。
入力した内容を POST で送信したければ、対象となった要素の innerHTML を form の内容にぶち込んであげるだけです。
改行も <br> で表現されるので、<input type="hidden"> に入れてあげれば大丈夫ですが、もちろん <textarea> でも大丈夫です。
<textarea> に入れる場合には、POST が完了するまでの一瞬の間、HTML な内容が見えてしまうので、スタイルで見えなくするなり、小さくするなりしておかないと、ちょっと不格好な感じです。
因みに画像は、data URI スキーム で表現されています。
こんな感じ(グリーンスターの画像です)。
<img src="">
対象となった要素の innerHTML の表現の一部として入ってますので、そのまま保存すれば画像も保存されます。
POST する form の onsubmit で #editor の innerHTML を取得して、form 内の要素に入れてあげる感じで良いと思います。
<form onsubmit="return put_editor_data()"> <textarea name="editor_data"></textarea> </form> <script> function put_editor_data() { $("TEXTAREA[name=editor_data]").val($("#editor").html()); return true; } </script>
的確なご回答ありがとうございました。
的確なご回答ありがとうございました。
2013/07/30 15:10:31