質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

Q&A

解決済

2回答

4276閲覧

Textarea内の文字数制限を超えたときに指定のモーダルウィンドウを警告として表示したいです!

anopurihana

総合スコア34

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

0グッド

0クリップ

投稿2017/06/13 07:17

編集2017/06/13 07:31

こんにちは、プログラミング初心者です。
現在、Monaca(HTML5+Javascriptのハイブリッドアプリ開発プラットフォーム)のベーシックプランにて初めてのアプリ開発に取り組んでいます。
その中で、Textarea内に文字制限を設け、超過すると警告ウインドウが出てくる仕組みを作っています。具体的には、ブラウザに依存するalertタグではなく、Tangle.jsというモーダルプラグインをダウンロードし、そのコードをTangle.jsホームページを参照して書き込みました。
現段階では、ユーザーが文字数制限を超えてTextarea内に入力を行った場合にこのモーダルウィンドウを警告として表示させたいのですが、その出し方がわかりません。以下がそのコードです。

<link rel="stylesheet" href="www/tingle.min.css">

Javascript

1<script type="text/javascript" src="www/tingle.min.js"> 2// instanciate new modal 3var modal = new tingle.modal({ 4 footer: true, 5 stickyFooter: false, 6 closeMethods: ['overlay', 'button', 'escape'], 7 closeLabel: "Close", 8 cssClass: ['custom-class-1', 'custom-class-2'], 9 onOpen: function() { 10 console.log('modal open'); 11 }, 12 onClose: function() { 13 console.log('modal closed'); 14 }, 15 beforeClose: function() { 16 // here's goes some logic 17 // e.g. save content before closing the modal 18 return true; // close the modal 19 return false; // nothing happens 20 } 21}); 22 23// set content 24modal.setContent('<h1>here\'s some content</h1>'); 25 26// add a button 27modal.addFooterBtn('Button label', 'tingle-btn tingle-btn--primary', function() { 28 // here goes some logic 29 modal.close(); 30}); 31 32// add another button 33modal.addFooterBtn('Dangerous action !', 'tingle-btn tingle-btn--danger', function() { 34 // here goes some logic 35 modal.close(); 36}); 37 38// open modal 39modal.open(); 40 41// close modal 42modal.close(); 43 44</script>

HTML

1<font> 2<div style="padding:0px 30px 30px 20px " "margin:10px 20px 10px 10px"> 3<textarea rows="3" cols="30" wrap="hard" 4 style="width:300px;height:100px;border-style:none;font-size:x-large;text-align:center;" 5 placeholder="Input your message!" 6 onchange="Limit(event)" onkeyup="Limit(event)"id="ttttt" > 7</textarea> 8</div> 9</font>

※質問と関連した部分のみ抜粋しています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kei344

2017/06/13 07:21

「見当がつきません」は何についてでしょうか。イベントでしょうか。文字列の取得でしょうかアラートの実行の仕方でしょうか。質問文を具体的に編集してください。
anopurihana

2017/06/13 07:29

kei344さん そうですね、表現が曖昧でした!具体的には”アラートの実行の仕方”です。質問文も編集しなおします。
guest

回答2

0

ベストアンサー

流れとしては
・textarea 内のキーボード押下、コピペをトリガーに文字数カウント
・超過時、モーダル表示を ON
とそれほど難しくないと思います。

問題は、ON したモーダルを消去したあとの挙動をどうするかというところです。もしコピペで、大幅にオーバーしてしまっていた場合、1文字消去するたびに、モーダルが ON されてしまいます。

以下のような回避策が必要かと
・消去は許容する
・モーダル表示後は、制限値内の文字数まで消去する
等々。

多分、モーダル消去後の実装のほうが面倒くさいと思います。
ご自身にできることを整理して、モーダル消去後の仕様を先に決めたほうが良いかと。

投稿2017/06/13 07:36

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

anopurihana

2017/06/13 08:32

te2jiさん ご回答ありがとうございます。 仰るように、モーダル消去後の処理のほうが大変そうです。消去後については、制限値内の文字数まで消去する方向で行きたいと思っています。実はモーダルウィンドウを取り入れる前はalertタグを使って警告を出していました。そのときは、こちらで指定した文字制限を超えると警告ウィンドウが表示され、それを消去すると自動的に剰余分の文字数が処理される仕組みができていました。しかしモーダルと組み合わせるとなると、どう組み合わせればよいかわからないのが現状です。
退会済みユーザー

退会済みユーザー

2017/06/13 08:38

yambejp さんのコード参考にするとイイですよ。
anopurihana

2017/06/13 09:07

te2jiさん お勧めしていただいたようにyambejpさんのコードで試してみましたが、うまくいきませんでした。特別エラーがあるわけではなかったです。
guest

0

ベタに書けばこんなかんじです

javascript

1var len_limit=10; 2function Limit(obj){ 3 if(obj.value.length>len_limit){ 4 alert("over"); 5 obj.value=obj.value.substr(0,len_limit) 6 return false; 7 } 8 return true; 9} 10

投稿2017/06/13 07:38

yambejp

総合スコア114779

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

anopurihana

2017/06/13 09:06

yambejpさん ご回答ありがとうございます。ご提案していただいたコードを試してみましたが、反映されませんでした。何か他に原因があると思いますので、探してみます。
yambejp

2017/06/13 09:07

あ、ごめんなさい onchange="Limit(this)" onkeyup="Limit(this)" というようにthisを引数で渡して下さい
anopurihana

2017/06/13 09:21

yambejpさん ご指摘していただいた通りにしたところ、警告ウィンドウが反映されました。しかし、警告ウィンドウのデザインを変更したいために、モーダルウィンドウを取り込むことに決めたので、alertタグを使うとウィンドウがブラウザに依存しているのでデザイン変更ができません。この場合、どのように用意したモーダルウィンドウと上でご提示いただいたようなイベントを結び付けられるかがわかりません。
kei344

2017/06/13 09:50

> どのように用意したモーダルウィンドウと上でご提示いただいたようなイベントを結び付けられるかがわかりません。 alert("over");の代わりに modal.open();
anopurihana

2017/06/13 11:54

kei344さん ご指摘ありがとうございます。実際に以下のように変更しましたが、反映されませんでした。 var len_limit=10; function Limit(obj){ if(obj.value.length>len_limit){ modal.open(); obj.value=obj.value.substr(0,len_limit) return false; } return true; }
anopurihana

2017/06/17 01:43

kei344さん わざわざ見やすいようにコードを作っていただきありがとうございます。確かに、制作していただいたページ上ではしっかり反映されていますね。実際に私のほうも書き換えてみましたが、やはり反映されません。他のコードが邪魔をしているのではないかと思い、すべて関係のないコードを一旦取り去ってみても効果がありませんでした。MonacaがTingleに対応していないということなのでしょうか・・・。
anopurihana

2017/06/18 03:28

namimonさん ご回答ありがとうございます。仰るようにOnsenUIを使ったほうが時間はかかってしまいますが安定するというご指摘を多くいただいたので、OnsenUIでモーダルを実装する方向で行きたいと思います。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問