css だけでドロップメニュー

CSS

html サンプル <ul class="dropmenu"> <li><a href="#">menu</a> <ul> <li><a href="#">sub1</a></li> <li><a href="#">sub2</a></li> <li><a href="#">sub3</a></li> <li><a href="#">sub4</a></li> </ul> </li> <li><span>menu</span> <ul> <li><a href="#">sub1</a></li> <li><a href="#">sub2</a></li> <li><a href="#">sub…</a></li></ul></li></ul>

css float属性の解除は、after疑似要素で。

CSS

今更。。。 css float属性の解除は、after疑似要素を使うのがいい。 <ul class="foo"> <li>a</li> <li>b</li> <li>c</li> </ul> <ul> <li>d</li> <li>e</li> <li>f</li> </ul> に対して、 .foo:after{ content: ""; display: block; clear: both; } .foo li{ float: left; list-style: none; width: 50px; border: 1px solid #808080; }

Wicket 8 FeedbackPanel サンプル

Wicket8 の AjaxButton onSubmit を使用して気がついたのだが、前の Wicket バージョンでは、onSubmit の中で任意に error(Serializable) を呼ぶと、onError が走るという認識だったけど、Wicket 8 でそう動かない。Validator を 仕掛けておいて、バリデーシ…

HTTPClient の ResponseHandler

HTTPClient といえば、 https://hc.apache.org/ の HttpClient この中の ResponseHandler は、残念なのか仕方ないのか、@FunctionalInterface を持っているわけではない。 あの面倒くさいHTTPで受け取る処理をもう少しスマートに書きたくて、とりあえず…

Wicket 8 で AJAX イベントビヘビアを Generic に

Wicket 8 で AJAX イベントビヘビアを oboe2uran.hatenablog.comと書いたものの、落ち着いてみれば、一般用に以下のとおり書けるし、その方がビヘビアを追加した先の コンポーネントを参照したビヘビアが書ける。。 import org.apache.wicket.Component; imp…

AJAXDownload ビヘビア、

Wicket8 が前提の話だが、ビヘビアをラムダで。。を考え出すと、次から次へと出てくる。。。 AJAX の振る舞いで動かすダウンロード、以前、 Wicket 6.x→7.x でファイルダウンロード時のファイル名の注意 - Oboe吹きプログラマの黙示録 この中で、public abst…

AjaxEventBehavior スクロール もラムダで。

Wicket8 ビヘビアもラムダの恩恵が沢山あるだろう。Wicket 7 で、SerializableConsumer が無かったおかげで例えば、AjaxEventBehavior で スクロールイベントの処理は 以下のようなクラスを用意して、 import org.apache.wicket.ajax.AjaxEventBehavior; imp…

Wicket7 の native Websocket を使う場合、jQuery UI 使用は注意。

Wicket7 の native Websocket を使うともう1つ、煩わしいことが見つかりました。Websocket 接続するページのHTMLの head タグの最後に、jQuery 設定として以下のように指定されてしまうのです。 <script type="text/javascript" src="./wicket/resource/org.apache.wicket.resource.JQueryResourceReference/jquery/jquery-1.12.4-ver-1489464145840.js"></script>

wicket nativeでURLパターンが /wicket/* でなければならない理由は

Wicket7 の native Websocket を使う時、web.xml に設定するWebSocketFilter の URLパターンが /wicket/* でなければならない 理由は、wicket-native-websocket-core-7.x-.jar の javascript = wicket-websocket-jquery.js で、Websocket 接続のURLプロ…

Wicket 7 native Websocket の制約?!

Wicket 7 で native Websocket を使ってサーバ PUSH に近いことをしようと作っていて、気持ち悪い制約に気が付いた。Wicket のサイト web.xml では、たいてい WebFilter として、org.apache.wicket.protocol.http.WebApplication 継承クラスのマッピングには…

Wicket 8 の AjaxButton 、Link など

Wicket 8 になるとこれまでよりもシリアライズ化された Consumer などによりラムダ記述は、 前に投稿した Wicket8 の LambdaModel - Oboe吹きプログラマの黙示録 の他に、AjaxButton 、FeedBackPanel 、Link なども簡潔に書けるようになってくる。AjaxButton…

Consumer を Inject

Google guice で、List をインジェクションする時によく使うのが、com.google.inject.TypeLiteral Java8 lambda の Consumer をインジェクションすることをやれば、条件分岐によるメソッド実行を 一括管理の記述ができると思った。まず、分岐ではなく、ただ…

NULLインジェクション

いつも、Google guice 使用を書いていて思うのが、NULLインジェクションが発生するとき、 @Nullable をつけて、Module の configure で、toProvider を書かなくてはならないのが 煩わしい。 binder().bind(Integer.class).toProvider(Providers.of(null)…

JavaFX CSS で @CHARSET記述は不要である

JavaFX の CSS を書いていると、ついHTMLのCSS を書いていた時の癖で @CHARSET "UTF-8"; を書いてしまう。でも、これを書いてしまうと、com.sun.javafx.css.parser.CSSParser は、CSS parseエラーになり思いとおりの スタイルが適用されなくなる。doc…

JavaFX の ウィンドウフレームを無くす

JavaFX の ウィンドウフレームを無くしたい場合、Application の start(Stage) で渡される javafx.stage.Stage をjavafx.stage.StageStyle の StageStyle.TRANSPARENT を指定すれば、ウィンドウフレーム無しの透過 StageStyle.UNDECORATED なら、ウィンドウ…

JavaFX で、外部フォント

JavaFX で、外部フォントを指定する場合の書き方CSS に書く場合 @font-faceで fontファミリ-ttfを定義、→ -fx-font-family で指定 @font-face{ font-family: meiryo; /** ttf ファイル参照 **/ src: url("file://c:/home/test/meiryo.ttf"); } Pane{ -fx-fon…

java.time.format.FormatStyle を確認

java.time.format.FormatStyle で Locale に従った日付表記を試してみる。 LocalDate.now().format(DateTimeFormatter.ofLocalizedDate(FormatStyle.FULL).withLocale(new Locale("ja", "JP"))); LocalDate.now().format(DateTimeFormatter.ofLocalizedDate(…

JavaFX のイニシャライズ処理を Google guice で整理

前回に引き続き、JavaFX のイニシャライズ処理を Google guice で整理してみる。 起動のメインクラス・・・共通イニシャライズとして、guice の Module を配置、 最初に起動されるコントローラ・・・次画面のイニシャライズとして Module を配置、 →画面遷移…

JavaFX で Google guice によって FXMLLoader のロードを補助する

JavaFX の Controller (←この呼び方が個人的には嫌い、MVCモデルの Cなんだろうけど)のファクトリの コールバックに、Google guice でのインジェクションを行う方法は、とても有効な手段だと思う。前回の投稿、 JavaFX の画面遷移、簡単に書く。 - Oboe吹…

JavaFX の画面遷移、簡単に書く。

JavaFX の画面遷移、Webページ閲覧のように切り替え、いろんなやり方のサンプルを見たけど、どれも釈然としない。もっとシンプルに書けるはずだ。javafx.application.Application継承の mainメソッドクラス public class MainApp extends Application{ st…

fxml ソースの配置

JavaFX の画面デザインレイアウトは一度決定してリリースしたらそんなに変更差し替えるものではなかろう。Maven で基本アーキタイプ生成のサンプル、GitHub - javafx-maven-plugin/javafx-basic-archetype: A Maven archetype for generating a basic JavaFX…

JavaFX Mavenサンプル

JavaFX の Maven 基本的なアーキタイプを探していて、GitHub - javafx-maven-plugin/javafx-basic-archetype: A Maven archetype for generating a basic JavaFX starter project.というのを見つけたので、ここに紹介されたとおり mvn コマンドを以下のよう…

今更、JavaFX の開発環境、

デザインレイアウトの為の fxml を編集するツール、もうバージョンUPされる見込みがなさそうで、何とかORACLEのダウンロードサイトを見つける。 JavaFX Scene Builder 2.0インストールhttp://www.oracle.com/technetwork/java/javafxscenebuilder-1x-archi…

Wicket 8 の websocket

2017年3月3日時点、Wicket 8.0.0-M4 の Websocket は、残念なことに、Tomcat8用の WebFilter が作られていない。wicket-native-websocket-tomcat/8.0.0-M3 は Central Repository にあっても wicket-native-websocket-tomcat/8.0.0-M4 は、まだ公開されて…

WebSocket の getOpenSessions は現在開いてるのを返す約束なのに。。

WebSocket の javax.websocket.Session の getOpenSessions は、現在開いてるセッションを全て返してくれるはずなのに、 サンプルを書いていて、どうも endpoint のセッションしか返してこない。。なぜ?Tomcat8.5.11 で試していた。。やりたかったのは、こ…

AttributeAppender とAttributeModifier lambda

Wicketの AttributeModifier と AttributeAppender は、よくよく考えたら、ラムダ式をあてはめられるんだった。 boolean isError; queue(new Label("name", itemname).add(new AttributeAppender("class", ()->isError ? "error" : "")));queue(new Label("n…

Wicket8 の LambdaModel

Wicket 8 になると待望のラムダ Model がある。PropertyModel を使って TextField に 自Pageクラスの変数を指定すると、どうしても new TextField<>("idname", new PropertyModel<>(this, "name"));のように書くことになり、"name" 変数名がタイプセーフでな…

Eclipse ロガーの自動挿入

Eclipse を設置して作業開始する前に設定しておく1つに、 Javaエディタでの ロガーの自動挿入がある、SL4J なら以下のように。。。 パターンに ${:import(org.slf4j.Logger, org.slf4j.LoggerFactory)}Logger logger = LoggerFactory.getLogger(this.getCla…

web.xml DOCTYPE記述メモ

今更だけど、web.xml 各Servletバージョン別の DOCTYPE記述メモ Servlet 2.3 <web-app> </web-app> Servlet 2.4

Tomcat8.5.11 を開発作業PC、EclipseWTPで起動する

Tomcat8.5.11 を開発作業PC(Windows)上に置いて、Eclipse WTP で動かしたくなった。Webサーバを Eclipse で指定しても、そのままでは、 The Apache Tomcat installation at this directory is version 8.5.11. A Tomcat 8.0 installation is expected. …

IntStream から逆順リストを作る

List<Integer> years = IntStream.rangeClosed(2013, Calendar.getInstance().get(Calendar.YEAR)) .boxed() .sorted(Comparator.reverseOrder()) .collect(Collectors.toList());</integer>

CSV書込み(1)(2)を書き直す。

CSV生成の oboe2uran.hatenablog.com と、 oboe2uran.hatenablog.com は、またもや書き直した。null 対応だ。

cssで書くメニューの例。。

メモ。。。 今さらだけど、以下で紹介された方法も使おう。 JSを使わずにCSSだけで作るドロワーメニュー – Web制作会社トライム

MySQL で UPSERT する時に考えること

SQL

MySQL で UPSERT をするとき、REPLACE を使うべきか? INSERT のオプション ON DUPLICATE KEY UPDATE を使うべきか?REPLACE は、キー重複する行を削除してから INSERT することを考えると、ON DUPLICATE KEY UPDATE の方が 更新する列を指定できるから良い…

日付期間重複の抽出

昨日、書いた日付期間のインターフェース DateSpan これを使って、BiConsumer の 期間が重複している重複日と重複した要素のリストを処理するメソッドを用意します。 public static void booklist(List list, BiConsumer<LocalDate, List<? super DateSpan>> bookConsumer){ AtomicInteger i = </localdate,>…

LocalDate の Stream 生成

開始日 LocalDate と 終了日 LocalDate 、 start 、 end の Stream int len = Period.between(start, end).getDays() + 1; Stream<LocalDate> stream = Stream.iterate(start, t->t.plusDays(1)).limit(len); ちょっと遊んだ、ふざけたコード StreamSupport.stream( Spl</localdate>…

DateSpan

日付期間に関する処理のために。。 import java.time.LocalDate; import java.time.Period; import java.util.AbstractMap; import java.util.AbstractMap.SimpleEntry; import java.util.ArrayList; import java.util.List; import java.util.function.Supp…

Combination の計算する程のことのない単純なペアの処理

単純にリストの項目を要素2個のペアで、全組み合わせの処理をするのに、数式 nCr に相当する処理を書いていたので 沢山の処理になってしまう。要素2個のペアの処理を全組み合わせを単純に行いたい。サンプル List<String> list = Arrays.asList( "a", "b", "c", "d</string>…

1行の table (HTML) を Java で解析する手法について

HTML 表(tableタグ) の1行もしくは数行の tr-td タグの文字列から単純に td の body に書かれた内容をJavaで抽出したいだけなのだが、 わざわざ、それだけの処理で SAXParser インスタンスや DOM インスタンスをつくって重くなるのが嫌になっ…

表の編集

前回の投稿、入力フィールドでよく使いそうな jQuery 処理のメモ http://oboe2uran.hatenablog.com/entry/2016/12/18/113206 と、 右クリックコンテキストメニューの基本サンプル http://oboe2uran.hatenablog.com/entry/2016/12/11/161826 右クリックコンテ…

入力フィールドでよく使いそうな jQuery 処理のメモ

HTML 入力フィールドでよく使いそうな jQuery 処理をまとめる。 /** * input-support.js */ /* for 全角数字入力→ 半角数字 */ var numberConvert = function(value){ var str = new String(value); var han = str.replace(/[0-9]/g, function(s){ return …

input タグ type="number" のスピンボタンを非表示

CSS

input タグ type="number" のスピンボタンを非表示にするCSSChrome と Safari input[type="number"]::-webkit-outer-spin-button, input[type="number"]::-webkit-inner-spin-button{ -webkit-appearance: none; margin: 0; } IE input[type="number"]{ -…

java.util.regex.Matcher とリスト置換

テンプレートのような、ある文字列の特定の文字をパラメータ文字列リストに置き換える処理は簡単だと思ってたが 以外と難しい。java.util.regex.Matcher を回した時に、置換メソッド実行していけば良いと思ってたが、 Matcher に、replaceFirst か replaceAl…

textarea 横スクロール

CSS

HTML textarea の wrap 属性って気が付けば wrap="off" は、もう使用しないんですね。横スクロールが自動で出るように wrap="off" を使うのではなく、 wrap="soft" と指定する。 もしくはCSSで、 textarea{ resize: none; white-space: pre; overflow-wra…

右クリックコンテキストメニューの基本サンプル

jQuery で右クリックコンテキストメニューを表示するのに気に入って使うようになったもの https://github.com/swisnl/jQuery-contextMenuhttps://swisnl.github.io/jQuery-contextMenu/以前、これを使用する時のアイコンを変える方法を書いた。→ コンテキス…

リスト順のままのグルーピングカウント

リストをキーによってカウントする=グルーピングしてカウントするのに変な要求の題を突き付けられました。 例えば、以下のようなクラスのObjectのリスト、(内部にカウンタを持ちグルーピングカウントの結果を持つもの)とします。 public class Item{ publ…

Arrays.asList が固定長のリストを返すことを忘れてはならない

訳あって String を確実に作れるカンマ区切りの文字列と単独の宣言済の String 数個 から 単独の宣言済の String を先頭に、String を作ることに少し悩みました。例えば、、 String str = "a,b,c"; String h1 = "1"; String h2 = "2"; String h3 = "3"; Stri…

GROUP_CONCAT を書く時の注意とメモ。

SQL

たまにしか書かない、GROUP_CONCAT の書式をよく忘れるのでメモ。 GROUP_CONCAT( 列名 [ ORDER BY 順序つける列名 ] [ SEPARATOR 区切り文字] ) 注意しなければならないのは CONCAT対象の列の値が NULL の場合、 SEPARATOR を指定しても区切り文字もつかず全…

MySQL Error code 1418 , ストアドFUNCTION 作成で、

MySQL で ストアドFUNCTION 作成で、 Error Code: 1418. This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators…

リストの比較、ListDiff

6年も前は、リストを比較して処理するのに、ブログ投稿したことを考えてたhttp://oboe2uran.hatenablog.com/entry/2010/07/01/121003http://oboe2uran.hatenablog.com/entry/2010/07/01/121003 http://oboe2uran.hatenablog.com/entry/2010/06/26/132425htt…