Microsoft Visioのような、UMLなどの図式を作成することができるサービスを、Webブラウザから使えるような形で作ろうと考えています。
この時、クライアントサイドは、HTML, CSS, JavaScriptで作るのがいいのでしょうか?サーバサイドはDjangoフレームワークを用いてPythonで書く予定です。
他の選択肢を知らないので、優劣じゃなくて単に「こんな選択肢もあるよ」という回答も歓迎します。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答3件
0
ベストアンサー
Webブラウザから使えるような形で作ろうと考えています。
フロントエンドで動作する為の選択肢がそもそもJavaScriptしか選択肢がありません。
(Flash、Javaアプレット等もありましたが死滅しました、数年後先にはWebAssemblyが流行るかもしれません)
ただし、既存言語から実行する直前にJavaScriptに変換するという手法を取る事もあります。
(所謂トランスパイル)
C/C++、Scala、Nim、LISPといった言語がJavaScriptにコンパイル出来ます、新しい言語はJSを意識しているものが多いようですね。
他にもJavaScriptに変換する専用の言語も存在します。
CoffeeScript, TypeScript, PureScript, LiveScript ...
クライアントサイドは、HTML, CSS, JavaScriptで作るのがいいのでしょうか?
素のHTMLやCSSを触るのも同様に辛いので、
静的ジェネレータを使う方法もあります。
HTML: Pug, Slim ...
CSS: SASS, Stylus ...
Microsoft Visioのような、UMLなどの図式を作成することができるサービスを、Webブラウザから使えるような形で作ろうと考えています。
コアの部分にも触れておきましょう。
マウスを使った作業が多くなるかと思います。
ブラウザ上でマウス操作を行った場合、ブラウザは逐一「マウスカーソルの座標が変わったよ!」とか「クリックされたよ!」といった情報をJavaScriptで受け取れる箇所に投げます。
イベントリスナーと呼ばれています。
第二引数のlistenerにJavaScriptの関数を設置しておくと、対象の操作が行われた時に登録しておいた関数をブラウザが実行してくれます。
スマートに書くのは難しいのであれこれ頑張ってください。
また、図形データはSGVが良いでしょう。
Canvasは駄目です。あれは2Dのレイヤーが1枚しかないようなものなので、設置したオブジェクトを二度と動かす事が出来ません。
SVG自体はテキストデータなので、Pythonサーバにアップロード、保存、ダウンロードの流れもわりと簡単に作れるでしょう。
JavaScript内でSVGをPNG画像に加工してDLさせるようなネタもあります。
投稿2017/10/31 12:12
総合スコア21158
0
Webブラウザって、HTML+JavaScript以外存在しないでしょ…
投稿2017/10/31 11:42
総合スコア1984
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/10/31 11:51
2017/10/31 12:00
2017/10/31 12:06
退会済みユーザー
2017/10/31 12:26
0
ブラウザ上で動くプログラム言語は JavaScript 以外無いと考えてもよいです。
JAVA Applet や Shockwave や Flash や JScript は現在ほとんど使われていません。
投稿2017/10/31 11:49
編集2017/10/31 11:50総合スコア69407
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2017/10/31 12:00
2017/10/31 12:37
退会済みユーザー
2017/10/31 13:12
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。