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

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

新規登録して質問してみよう
ただいま回答率
85.48%
SPA(Single-page Application)

SPA(Single-page Application)は、単一のWebページのみでコンテンツの切り替えができるWebアプリケーションもしくはWebサイトです。ブラウザでのページ遷移がないため、デスクトップアプリケーションのようなUXを提供します。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

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

Onsen UI

HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

Q&A

解決済

1回答

1320閲覧

【 JavaScript × Rails 】SPAでURLを設定する方法

marion

総合スコア18

SPA(Single-page Application)

SPA(Single-page Application)は、単一のWebページのみでコンテンツの切り替えができるWebアプリケーションもしくはWebサイトです。ブラウザでのページ遷移がないため、デスクトップアプリケーションのようなUXを提供します。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

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

Onsen UI

HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

0グッド

1クリップ

投稿2019/03/04 05:01

編集2019/03/05 14:50

javascript(onsenui利用)でSPAを構築しています。(Railsに乗せています)
外部からURL直打ちで該当のtemplateを表示したindex.htmlに飛ばすことができません。

分からないこと

の2パターンが分かりません。

routes.rbには

Rails.application.routes.draw do ... # settings get "settings" => "pages#settings" # user get "user" => "pages#user"

こんな感じで現在記載をしています。
例えばhttp://aaa.com/settingsにアクセスするとtemplate化されているのでsettings.html単体で表示されます。(当然ですが、cssなども効きません)

js側でurlを指定してあげる方法、またはRailsと連携して指定する方法
ご存知の方ご教示いただければ幸いです。

onsenui、ons-navigator内のons-template切り替え時にurlを発行し直打ち対応させるのが目標ですが、
onsenuiではなく純粋htmlとjavascriptでのやり方でも構いません。
(page.jsなど見てみたのですが組み合わせ方がよく分からず・・それでも構いません)

何卒よろしくお願いいたします。

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

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

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

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

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

urbainleverrier

2019/03/12 15:58 編集

「settings.html表示時http://aaa.com/settingsにしたい場合」おそらくhistory apiを使えばいいのではないでしょうか。 history.replaceState('','','/settings'); history.replaceState('','','/user/123); ただ、この手の内容はフロントサイドのフレームワーク(angularやreact、vue)がカバーしていますので、そちらのドキュメントを参考にするといいと思います
marion

2019/03/20 08:03

routerかhistory api検討して利用してみます、ありがとうございます!
guest

回答1

0

自己解決

history api
https://developer.mozilla.org/ja/docs/Web/Guide/DOM/Manipulating_the_browser_history
の利用を検討します。tktktさんありがとうございました。

投稿2019/03/20 08:06

marion

総合スコア18

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問