{"id":2909,"date":"2021-11-21T15:12:39","date_gmt":"2021-11-21T06:12:39","guid":{"rendered":"https:\/\/suzutukiblog.com\/?p=2909"},"modified":"2022-01-22T08:09:43","modified_gmt":"2022-01-21T23:09:43","slug":"rails-tutorial-7","status":"publish","type":"post","link":"https:\/\/suzutukiblog.com\/index.php\/2021\/11\/21\/rails-tutorial-7\/","title":{"rendered":"Rails-tutorial\u81ea\u5206\u7528\u307e\u3068\u3081(\u7b2c7\u7ae0\u30e6\u30fc\u30b6\u30fc\u767b\u9332 \u4e3b\u306b\u6f14\u7fd2\u3068\u305d\u306e\u56de\u7b54)"},"content":{"rendered":"<p><a href=\"https:\/\/suzutukiblog.com\/index.php\/2021\/04\/18\/rails-tutorial-6\/\">\u305d\u306e6\u304b\u3089\u7d9a\u304d\u307e\u3059<\/a><\/p>\n<h3><span class=\"number\">7.1.1\u00a0<\/span>\u30c7\u30d0\u30c3\u30b0\u3068Rails\u74b0\u5883<\/h3>\n<div class=\"heading\"><span class=\"description\">\u30b5\u30a4\u30c8\u306e\u30ec\u30a4\u30a2\u30a6\u30c8\u306b\u30c7\u30d0\u30c3\u30b0\u60c5\u5831\u3092\u8ffd\u52a0\u3059\u308b<strong><code class=\"filepath\">app\/views\/layouts\/application.html.erb<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"cp\">&lt;!DOCTYPE html&gt;<\/span>\r\n<span class=\"p\">&lt;<\/span><span class=\"nt\">html<\/span><span class=\"p\">&gt;<\/span>\r\n  .\r\n  .\r\n  .\r\n  <span class=\"p\">&lt;<\/span><span class=\"nt\">body<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">render<\/span> <span class=\"s1\">'layouts\/header'<\/span> <span class=\"cp\">%&gt;<\/span>\r\n    <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"container\"<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"k\">yield<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">render<\/span> <span class=\"s1\">'layouts\/footer'<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<span class=\"hll\">      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">debug<\/span><span class=\"p\">(<\/span><span class=\"n\">params<\/span><span class=\"p\">)<\/span> <span class=\"k\">if<\/span> <span class=\"no\">Rails<\/span><span class=\"o\">.<\/span><span class=\"n\">env<\/span><span class=\"o\">.<\/span><span class=\"n\">development?<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<\/span>    <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">&lt;\/<\/span><span class=\"nt\">body<\/span><span class=\"p\">&gt;<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<div class=\"heading\">\u00a0<span class=\"description\">\u30c7\u30d0\u30c3\u30b0\u8868\u793a\u3092\u6574\u5f62\u3059\u308b\u305f\u3081\u306e\u8ffd\u52a0\u3068\u3001Sass\u306e\u30df\u30c3\u30af\u30b9\u30a4\u30f3.<\/span><\/div>\n<div class=\"heading\"><span class=\"description\"><strong><code class=\"filepath\">app\/assets\/stylesheets\/custom.scss<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"k\">@import<\/span> <span class=\"s2\">\"bootstrap-sprockets\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">@import<\/span> <span class=\"s2\">\"bootstrap\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"cm\">\/* mixins, variables, etc. *\/<\/span>\r\n\r\n<span class=\"nv\">$gray-medium-light<\/span><span class=\"o\">:<\/span> <span class=\"mh\">#eaeaea<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"hll\"><span class=\"k\">@mixin<\/span><span class=\"nf\"> box_sizing<\/span> <span class=\"p\">{<\/span><\/span><span class=\"hll\"><span class=\"nt\">-moz-box-sizing<\/span><span class=\"nd\">:<\/span>    <span class=\"nt\">border-box<\/span><span class=\"o\">;<\/span><\/span><span class=\"hll\"><span class=\"nt\">-webkit-box-sizing<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">border-box<\/span><span class=\"o\">;<\/span><\/span><span class=\"hll\"><span class=\"nt\">box-sizing<\/span><span class=\"nd\">:<\/span>         <span class=\"nt\">border-box<\/span><span class=\"o\">;<\/span><\/span><span class=\"hll\"><span class=\"p\">}<\/span><\/span><span class=\"nc\">.<\/span>\r\n<span class=\"nc\">.<\/span>\r\n<span class=\"nc\">.<\/span>\r\n<span class=\"hll\"><span class=\"o\">\/*<\/span> <span class=\"nt\">miscellaneous<\/span> <span class=\"o\">*\/<\/span><\/span>\r\n<span class=\"hll\"><span class=\"nc\">.debug_dump<\/span> <span class=\"p\">{<\/span><\/span><span class=\"hll\"><span class=\"nt\">clear<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">both<\/span><span class=\"o\">;<\/span><\/span><span class=\"hll\"><span class=\"nt\">float<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">left<\/span><span class=\"o\">;<\/span><\/span><span class=\"hll\"><span class=\"nt\">width<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">100<\/span><span class=\"err\">%<\/span><span class=\"o\">;<\/span><\/span><span class=\"hll\"><span class=\"nt\">margin-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">45px<\/span><span class=\"o\">;<\/span><\/span><\/strong> <strong><span class=\"nt\">-moz-box-sizing<\/span><span class=\"nd\">:<\/span>    <span class=\"nt\">border-box<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"nt\">-webkit-box-sizing<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">border-box<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"nt\">box-sizing<\/span><span class=\"nd\">:<\/span>         <span class=\"nt\">border-box<\/span><span class=\"o\">;\r\n<\/span><\/strong><strong><span class=\"hll\"><span class=\"p\">}<\/span><\/span><\/strong><\/pre>\n<\/div>\n<h2>\u6f14\u7fd2<\/h2>\n<h3>1:\u30d6\u30e9\u30a6\u30b6\u304b\u3089 \/about \u306b\u30a2\u30af\u30bb\u30b9\u3057\u3001\u30c7\u30d0\u30c3\u30b0\u60c5\u5831\u304c\u8868\u793a\u3055\u308c\u3066\u3044\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/h3>\n<p>\u3053\u306e\u30da\u30fc\u30b8\u3092\u8868\u793a\u3059\u308b\u3068\u304d\u3001\u3069\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u3068\u30a2\u30af\u30b7\u30e7\u30f3\u304c\u4f7f\u308f\u308c<br \/>\n\u3066\u3044\u305f\u3067\u3057\u3087\u3046\u304b? params\u306e\u5185\u5bb9\u304b\u3089\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<pre><strong>controller: static_pages<\/strong>\r\n<strong>action: about<\/strong><\/pre>\n<h3>2:Rails\u30b3\u30f3\u30bd\u30fc\u30eb\u3092\u958b\u304d\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u304b\u3089\u6700\u521d\u306e\u30e6\u30fc\u30b6\u30fc\u60c5\u5831\u3092\u53d6\u5f97\u3057\u3001\u5909\u6570user\u306b\u683c\u7d0d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/h3>\n<p>\u305d\u306e\u5f8c\u3001puts user.attributes.to_yaml\u3092\u5b9f\u884c\u3059\u308b\u3068\u4f55\u304c\u8868\u793a\u3055\u308c\u307e\u3059\u304b?<br \/>\n\u3053\u3053\u3067\u8868\u793a\u3055\u308c\u305f\u7d50\u679c\u3068\u3001y\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3063\u305fy user.attributes\u306e\u5b9f\u884c\u7d50\u679c\u3092\u6bd4\u8f03\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<pre><strong>user = User.first<\/strong><\/pre>\n<p>\u8868\u793a\u306f\u540c\u3058<\/p>\n<pre><strong>HTTP   \u30ea\u30af\u30a8\u30b9\u30c8URL  \u30a2\u30af\u30b7\u30e7\u30f3 \u540d\u524d\u4ed8\u304d\u30eb\u30fc\u30c8        \u7528\u9014<\/strong>\r\n<strong>GET    \/users       index   users_path     \u3059\u3079\u3066\u306e\u30e6\u30fc\u30b6\u30fc\u3092\u4e00\u89a7\u3059\u308b\u30da\u30fc\u30b8<\/strong>\r\n<strong>GET    \/users\/1     show    user_path(user) \u7279\u5b9a\u306e\u30e6\u30fc\u30b6\u30fc\u3092\u8868\u793a\u3059\u308b\u30da\u30fc\u30b8<\/strong>\r\n<strong>GET    \/users\/new   new     new_user_path  \u30e6\u30fc\u30b6\u30fc\u3092\u65b0\u898f\u4f5c\u6210\u3059\u308b\u30da\u30fc\u30b8 (\u30e6\u30fc\u30b6\u30fc\u767b\u9332)<\/strong>\r\n<strong>POST   \/users       create  users_path     \u30e6\u30fc\u30b6\u30fc\u3092\u4f5c\u6210\u3059\u308b\u30a2\u30af\u30b7\u30e7\u30f3<\/strong>\r\n<strong>GET    \/users\/1\/    edit    edit edit_user_path(user) id=1\u306e\u30e6\u30fc\u30b6\u30fc\u3092\u7de8\u96c6\u3059\u308b\u30da\u30fc\u30b8<\/strong>\r\n<strong>PATCH  \/users\/1     update  user_path(user) \u30e6\u30fc\u30b6\u30fc\u3092\u66f4\u65b0\u3059\u308b\u30a2\u30af\u30b7\u30e7\u30f3<\/strong>\r\n<strong>DELETE \/users\/1     destroy user_path(user) \u30e6\u30fc\u30b6\u30fc\u3092\u524a\u9664\u3059\u308b\u30a2\u30af\u30b7\u30e7\u30f3<\/strong>\r\n<strong>Users\u30ea\u30bd\u30fc\u30b9\u304c\u63d0\u4f9b\u3059\u308bRESTful\u306a\u30eb\u30fc\u30c8<\/strong><\/pre>\n<h3>\u6f14\u7fd2<\/h3>\n<p>\u57cb\u3081\u8fbc\u307fRuby\u3092\u4f7f\u3063\u3066\u3001\u30de\u30b8\u30c3\u30af\u30ab\u30e9\u30e0 (created_at\u3068updated_at)<br \/>\n\u306e\u5024\u3092show\u30da\u30fc\u30b8\u306b\u8868\u793a\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u57cb\u3081\u8fbc\u307fRuby\u3092\u4f7f\u3063\u3066\u3001<br \/>\nTime.now\u306e\u7d50\u679c\u3092show\u30da\u30fc\u30b8\u306b\u8868\u793a\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<br \/>\n\u30da\u30fc\u30b8\u3092\u66f4\u65b0\u3059\u308b\u3068\u3001\u305d\u306e\u7d50\u679c\u306f\u3069\u3046\u5909\u308f\u3063\u3066\u3044\u307e\u3059\u304b? \u78ba\u8a8d\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre><strong>&lt;%= @user.name %&gt;, &lt;%= @user.email %&gt;,<\/strong>\r\n<strong>&lt;%= @user.updated_at %&gt;, &lt;%= @user.created_at %&gt;,<\/strong>\r\n<strong>&lt;%= Time.now %&gt;<\/strong><\/pre>\n<h3><!--more--><\/h3>\n<h2>\u6f14\u7fd2<\/h2>\n<h3>1:show\u30a2\u30af\u30b7\u30e7\u30f3\u306e\u4e2d\u306bdebugger\u3092\u5dee\u3057\u8fbc\u307f\u30d6\u30e9\u30a6\u30b6\u304b\u3089\/users\/1<br \/>\n\u306b\u30a2\u30af\u30bb\u30b9\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/h3>\n<p>\u305d\u306e\u5f8c\u30b3\u30f3\u30bd\u30fc\u30eb\u306b\u79fb\u308a\u3001puts\u30e1\u30bd\u30c3\u30c9\u3092<br \/>\n\u4f7f\u3063\u3066params\u30cf\u30c3\u30b7\u30e5\u306e\u4e2d\u8eab\u3092YAML\u5f62\u5f0f\u3067\u8868\u793a\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<pre><strong>a = params<\/strong>\r\n<strong>&lt;ActionController::Parameters {\"controller\"=&gt;\"users\", \"action\"=&gt;\"show\", \"id\"=&gt;\"1\"} permitted: false&gt;<\/strong>\r\n<strong>(byebug) puts a.to_yaml<\/strong>\r\n<strong>--- !ruby\/object:ActionController::Parameters<\/strong>\r\n<strong>parameters: !ruby\/hash:ActiveSupport::HashWithIndifferentAccess<\/strong>\r\n<strong>controller: users<\/strong>\r\n<strong>action: show<\/strong>\r\n<strong>id: '1'<\/strong>\r\n<strong>permitted: false<\/strong>\r\n<strong>nil<\/strong><\/pre>\n<h3>2:new\u30a2\u30af\u30b7\u30e7\u30f3\u306e\u4e2d\u306bdebugger\u3092\u5dee\u3057\u8fbc\u307f\u3001\/users\/new \u306b\u30a2\u30af\u30bb\u30b9\u3057<br \/>\n\u3066\u307f\u307e\u3057\u3087\u3046\u3002@user\u306e\u5185\u5bb9\u306f\u3069\u306e\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u308b\u3067\u3057\u3087\u3046\u304b?<\/h3>\n<pre><strong>@user<\/strong>\r\n<strong>nil<\/strong><\/pre>\n<p>Digest\u30e9\u30a4\u30d6\u30e9\u30ea\u306ehexdigest\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3046\u3068\u3001<br \/>\nMD5\u306e\u30cf\u30c3\u30b7\u30e5\u5316\u304c\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n<pre><span class=\"gp\">&gt;&gt; <\/span><span class=\"n\">email<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"MHARTL@example.COM\"<\/span>\r\n<span class=\"hll\"><span class=\"gp\">&gt;&gt; <\/span><span class=\"no\">Digest<\/span><span class=\"o\">::<\/span><span class=\"no\">MD5<\/span><span class=\"o\">::<\/span><strong><span class=\"n\">hexdigest<\/span><\/strong><span class=\"p\">(<\/span><span class=\"n\">email<\/span><span class=\"o\">.<\/span><span class=\"n\">downcase<\/span><span class=\"p\">)<\/span>\r\n<\/span><span class=\"go\">=&gt; \"1fda4469bcbec3badf5418269ffc5968\"<\/span><\/pre>\n<div class=\"heading\"><span class=\"description\"><code>gravatar_for<\/code>\u30d8\u30eb\u30d1\u30fc\u30e1\u30bd\u30c3\u30c9\u3092\u5b9a\u7fa9\u3059\u308b<\/span><\/div>\n<div class=\"heading\"><span class=\"description\"><strong><code class=\"filepath\">app\/helpers\/users_helper.rb<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"k\">module<\/span> <span class=\"nn\">UsersHelper<\/span>\r\n\r\n<\/strong>  <span class=\"c1\"># \u5f15\u6570\u3067\u4e0e\u3048\u3089\u308c\u305f\u30e6\u30fc\u30b6\u30fc\u306eGravatar\u753b\u50cf\u3092\u8fd4\u3059\r\n<\/span><strong><span class=\"k\">  def<\/span> <span class=\"nf\">gravatar_for<\/span><span class=\"p\">(<\/span><span class=\"n\">user<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"n\">gravatar_id<\/span> <span class=\"o\">=<\/span> <span class=\"no\">Digest<\/span><span class=\"o\">::<\/span><span class=\"no\">MD5<\/span><span class=\"o\">::<\/span><span class=\"n\">hexdigest<\/span><span class=\"p\">(<\/span><span class=\"n\">user<\/span><span class=\"o\">.<\/span><span class=\"n\">email<\/span><span class=\"o\">.<\/span><span class=\"n\">downcase<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"n\">gravatar_url<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"https:\/\/secure.gravatar.com\/avatar\/<\/span><span class=\"si\">#{<\/span><span class=\"n\">gravatar_id<\/span><span class=\"si\">}<\/span><span class=\"s2\">\"<\/span>\r\n    <span class=\"n\">image_tag<\/span><span class=\"p\">(<\/span><span class=\"n\">gravatar_url<\/span><span class=\"p\">,<\/span> <span class=\"ss\">alt<\/span><span class=\"p\">:<\/span> <span class=\"n\">user<\/span><span class=\"o\">.<\/span><span class=\"n\">name<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"gravatar\"<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"k\">end<\/span>\r\n<span class=\"k\">end<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<p>\u30e6\u30fc\u30b6\u30fc\u306e\u30b5\u30a4\u30c9\u30d0\u30fc\u306e\u6700\u521d\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u4f5c\u308a\u307e\u3057\u3087\u3046\u3002\u3053\u3053\u3067\u306faside\u30bf\u30b0\u3092\u4f7f\u3063\u3066\u5b9f\u88c5\u3057\u307e\u3059\u3002\u3053\u306e\u30bf\u30b0\u306f\u30b5\u30a4\u30c9\u30d0\u30fc\u306a\u3069\u306e\u88dc\u5b8c\u30b3\u30f3\u30c6\u30f3\u30c4\u306e\u8868\u793a\u306b\u4f7f\u308f\u308c\u307e\u3059\u304c\u3001\u5358\u72ec\u3067\u8868\u793a\u3059\u308b\u3053\u3068\u3082\u3067\u304d\u307e\u3059\u3002row\u30af\u30e9\u30b9\u3068col-md-4\u30af\u30e9\u30b9\u3082\u8ffd\u52a0\u3057\u3066\u304a\u304d\u307e\u3059\u3002\u3053\u308c\u3089\u306e\u30af\u30e9\u30b9\u306fBootstrap\u306e\u4e00\u90e8\u3067\u3059\u3002\u30e6\u30fc\u30b6\u30fc\u8868\u793a\u30da\u30fc\u30b8\u3092\u5909\u66f4\u3057\u305f\u7d50\u679c\u3092\u30ea\u30b9\u30c8 7.10\u306b\u793a\u3057\u307e\u3059\u3002<\/p>\n<div class=\"heading\"><span class=\"description\"><code>show<\/code>\u30d3\u30e5\u30fc\u306b\u30b5\u30a4\u30c9\u30d0\u30fc\u3092\u8ffd\u52a0\u3059\u308b<strong><code class=\"filepath\">app\/views\/users\/show.html.erb<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"cp\">&lt;%<\/span> <span class=\"n\">provide<\/span><span class=\"p\">(<\/span><span class=\"ss\">:title<\/span><span class=\"p\">,<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.<\/span><span class=\"n\">name<\/span><span class=\"p\">)<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"row\"<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">&lt;<\/span><span class=\"nt\">aside<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"col-md-4\"<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;<\/span><span class=\"nt\">section<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"user_info\"<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"p\">&lt;<\/span><span class=\"nt\">h1<\/span><span class=\"p\">&gt;<\/span>\r\n        <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">gravatar_for<\/span> <span class=\"vi\">@user<\/span> <span class=\"cp\">%&gt;<\/span>\r\n        <span class=\"cp\">&lt;%=<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.<\/span><span class=\"n\">name<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"p\">&lt;\/<\/span><span class=\"nt\">h1<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;\/<\/span><span class=\"nt\">section<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">&lt;\/<\/span><span class=\"nt\">aside<\/span><span class=\"p\">&gt;<\/span>\r\n<span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<div class=\"heading\"><span class=\"description\">SCSS\u3092\u4f7f\u3063\u3066\u30b5\u30a4\u30c9\u30d0\u30fc\u306a\u3069\u306e\u30e6\u30fc\u30b6\u30fc\u8868\u793a\u30da\u30fc\u30b8\u306b\u30b9\u30bf\u30a4\u30eb\u3092\u4e0e\u3048\u308b<strong><code class=\"filepath\">app\/assets\/stylesheets\/custom.scss<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"nc\">.<\/span>\r\n<span class=\"nc\">.<\/span>\r\n<span class=\"nc\">.<\/span>\r\n<span class=\"o\">\/*<\/span> <span class=\"nt\">sidebar<\/span> <span class=\"o\">*\/<\/span>\r\n\r\n<span class=\"nt\">aside<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nt\">section<\/span><span class=\"nc\">.user_info<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">margin-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">20px<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"nt\">section<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">padding<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">10px<\/span> <span class=\"nt\">0<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">margin-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">20px<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"k\">&amp;<\/span><span class=\"nd\">:first-child<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nt\">border<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">0<\/span><span class=\"o\">;<\/span>\r\n      <span class=\"nt\">padding-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">0<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n    <span class=\"nt\">span<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nt\">display<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">block<\/span><span class=\"o\">;<\/span>\r\n      <span class=\"nt\">margin-bottom<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">3px<\/span><span class=\"o\">;<\/span>\r\n      <span class=\"nt\">line-height<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">1<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n    <span class=\"nt\">h1<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nt\">font-size<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">1<\/span><span class=\"nc\">.4em<\/span><span class=\"o\">;<\/span>\r\n      <span class=\"nt\">text-align<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">left<\/span><span class=\"o\">;<\/span>\r\n      <span class=\"nt\">letter-spacing<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">-1px<\/span><span class=\"o\">;<\/span>\r\n      <span class=\"nt\">margin-bottom<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">3px<\/span><span class=\"o\">;<\/span>\r\n      <span class=\"nt\">margin-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">0px<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nc\">.gravatar<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nt\">float<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">left<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"nt\">margin-right<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">10px<\/span><span class=\"o\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nc\">.gravatar_edit<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nt\">margin-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">15px<\/span><span class=\"o\">;<\/span>\r\n<span class=\"p\">}<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<h3>\u6f14\u7fd2<\/h3>\n<p>\u5b9a\u7fa9\u3057\u305fgravatar_for\u30d8\u30eb\u30d1\u30fc\u3092\u5909\u66f4\u3057\u3066\u3001<br \/>\nsize\u3092\u30aa\u30d7\u30b7\u30e7\u30f3\u5f15\u6570\u3068\u3057\u3066\u53d7\u3051\u53d6\u308c\u308b\u3088\u3046\u306b\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<br \/>\n\u3046\u307e\u304f\u5909\u66f4\u3067\u304d\u308b\u3068\u3001gravatar_for user, size: 50\u3068\u3044\u3063\u305f\u547c\u3073\u51fa\u3057\u65b9\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<br \/>\n\u91cd\u8981:\u3053\u306e\u6539\u5584\u3057\u305f\u30d8\u30eb\u30d1\u30fc\u306f10.3.1\u3067\u5b9f\u969b\u306b\u4f7f\u3044\u307e\u3059\u3002\u5fd8\u308c\u305a\u306b\u5b9f\u88c5\u3057\u3066\u304a\u304d\u307e\u3057\u3087\u3046<\/p>\n<div class=\"heading\"><span class=\"description\"><code>gravatar_for<\/code>\u30d8\u30eb\u30d1\u30fc\u306b\u30aa\u30d7\u30b7\u30e7\u30f3\u5f15\u6570\u3092\u8ffd\u52a0\u3059\u308b<strong><code class=\"filepath\">app\/helpers\/users_helper.rb<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"k\">module<\/span> <span class=\"nn\">UsersHelper<\/span>\r\n\r\n<\/strong>  <span class=\"c1\"># \u5f15\u6570\u3067\u4e0e\u3048\u3089\u308c\u305f\u30e6\u30fc\u30b6\u30fc\u306eGravatar\u753b\u50cf\u3092\u8fd4\u3059\r\n<\/span><strong><span class=\"hll\"><span class=\"k\">def<\/span> <span class=\"nf\">gravatar_for<\/span><span class=\"p\">(<\/span><span class=\"n\">user<\/span><span class=\"p\">,<\/span> <span class=\"n\">options<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span> <span class=\"ss\">size<\/span><span class=\"p\">:<\/span> <span class=\"mi\">80<\/span> <span class=\"p\">})<\/span><\/span> \r\n   <span class=\"n\">gravatar_id<\/span> <span class=\"o\">=<\/span> <span class=\"no\">Digest<\/span><span class=\"o\">::<\/span><span class=\"no\">MD5<\/span><span class=\"o\">::<\/span><span class=\"n\">hexdigest<\/span><span class=\"p\">(<\/span><span class=\"n\">user<\/span><span class=\"o\">.<\/span><span class=\"n\">email<\/span><span class=\"o\">.<\/span><span class=\"n\">downcase<\/span><span class=\"p\">)<\/span>\r\n<span class=\"hll\"><span class=\"n\">size<\/span> <span class=\"o\">=<\/span> <span class=\"n\">options<\/span><span class=\"o\">[<\/span><span class=\"ss\">:size<\/span><span class=\"o\">]\r\n<\/span><\/span><span class=\"hll\"><span class=\"n\">gravatar_url<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"https:\/\/secure.gravatar.com\/avatar\/<\/span><span class=\"si\">#{<\/span><span class=\"n\">gravatar_id<\/span><span class=\"si\">}<\/span><span class=\"s2\">?s=<\/span><span class=\"si\">#{<\/span><span class=\"n\">size<\/span><span class=\"si\">}<\/span><span class=\"s2\">\"<\/span><\/span> \r\n   <span class=\"n\">image_tag<\/span><span class=\"p\">(<\/span><span class=\"n\">gravatar_url<\/span><span class=\"p\">,<\/span> <span class=\"ss\">alt<\/span><span class=\"p\">:<\/span> <span class=\"n\">user<\/span><span class=\"o\">.<\/span><span class=\"n\">name<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"gravatar\"<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"k\">end<\/span>\r\n<span class=\"k\">end<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<p>3:\u30aa\u30d7\u30b7\u30e7\u30f3\u5f15\u6570\u306f\u4eca\u3067\u3082Ruby\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u3067\u4e00\u822c\u7684\u306b\u4f7f\u308f\u308c\u3066\u3044\u307e\u3059\u304c\u3001Ruby 2.0\u304b\u3089\u5c0e\u5165\u3055\u308c\u305f\u65b0\u6a5f\u80fd\u300c<strong>\u30ad\u30fc\u30ef\u30fc\u30c9\u5f15\u6570 (Keyword Arguments)<\/strong>\u300d\u3067\u3082\u5b9f\u73fe\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u5148\u307b\u3069\u5909\u66f4\u3057\u305f\u30ea\u30b9\u30c8\u3092\u7f6e\u304d\u63db\u3048\u3066\u3082\u3046\u307e\u304f\u52d5\u304f\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u3053\u306e\uff12\u3064\u306e\u5b9f\u88c5\u65b9\u6cd5\u306f\u3069\u3046\u3044\u3063\u305f\u9055\u3044\u304c\u3042\u308b\u306e\u3067\u3057\u3087\u3046\u304b? \u8003\u3048\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<div class=\"heading\"><span class=\"description\"><code>gravatar_for<\/code>\u30d8\u30eb\u30d1\u30fc\u306b\u30ad\u30fc\u30ef\u30fc\u30c9\u5f15\u6570\u3092\u8ffd\u52a0\u3059\u308b<\/span><\/div>\n<div class=\"heading\"><span class=\"description\"><code class=\"filepath\"><strong>app\/helpers\/users_helper.rb<\/strong><\/code><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"k\">module<\/span> <span class=\"nn\">UsersHelper<\/span>\r\n\r\n<\/strong>  <span class=\"c1\"># \u5f15\u6570\u3067\u4e0e\u3048\u3089\u308c\u305f\u30e6\u30fc\u30b6\u30fc\u306eGravatar\u753b\u50cf\u3092\u8fd4\u3059\r\n<\/span><strong><span class=\"hll\"><span class=\"k\">  def<\/span> <span class=\"nf\">gravatar_for<\/span><span class=\"p\">(<\/span><span class=\"n\">user<\/span><span class=\"p\">,<\/span> <span class=\"ss\">size<\/span><span class=\"p\">:<\/span> <span class=\"mi\">80<\/span><span class=\"p\">)\r\n<\/span><\/span>    <span class=\"n\">gravatar_id<\/span> <span class=\"o\">=<\/span> <span class=\"no\">Digest<\/span><span class=\"o\">::<\/span><span class=\"no\">MD5<\/span><span class=\"o\">::<\/span><span class=\"n\">hexdigest<\/span><span class=\"p\">(<\/span><span class=\"n\">user<\/span><span class=\"o\">.<\/span><span class=\"n\">email<\/span><span class=\"o\">.<\/span><span class=\"n\">downcase<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"n\">gravatar_url<\/span> <span class=\"o\">=<\/span> <span class=\"s2\">\"https:\/\/secure.gravatar.com\/avatar\/<\/span><span class=\"si\">#{<\/span><span class=\"n\">gravatar_id<\/span><span class=\"si\">}<\/span><span class=\"s2\">?s=<\/span><span class=\"si\">#{<\/span><span class=\"n\">size<\/span><span class=\"si\">}<\/span><span class=\"s2\">\"<\/span>\r\n    <span class=\"n\">image_tag<\/span><span class=\"p\">(<\/span><span class=\"n\">gravatar_url<\/span><span class=\"p\">,<\/span> <span class=\"ss\">alt<\/span><span class=\"p\">:<\/span> <span class=\"n\">user<\/span><span class=\"o\">.<\/span><span class=\"n\">name<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"gravatar\"<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"k\">end<\/span>\r\n<span class=\"k\">end<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<h3><span class=\"number\">7.2.1\u00a0<\/span><strong><code class=\"tt\">form_for<\/code><\/strong>\u3092\u4f7f\u7528\u3059\u308b<\/h3>\n<div class=\"heading\"><span class=\"description\"><code>new<\/code>\u30a2\u30af\u30b7\u30e7\u30f3\u306b<code>@user<\/code>\u5909\u6570\u3092\u8ffd\u52a0\u3059\u308b<\/span><\/div>\n<div class=\"heading\"><span class=\"description\"><code class=\"filepath\"><strong>app\/controllers\/users_controller.rb<\/strong><\/code><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"k\">class<\/span> <span class=\"nc\">UsersController<\/span> <span class=\"o\">&lt;<\/span> <span class=\"no\">ApplicationController<\/span>\r\n\r\n  <span class=\"k\">def<\/span> <span class=\"nf\">show<\/span>\r\n    <span class=\"vi\">@user<\/span> <span class=\"o\">=<\/span> <span class=\"no\">User<\/span><span class=\"o\">.<\/span><span class=\"n\">find<\/span><span class=\"p\">(<\/span><span class=\"n\">params<\/span><span class=\"o\">[<\/span><span class=\"ss\">:id<\/span><span class=\"o\">]<\/span><span class=\"p\">)<\/span>\r\n  <span class=\"k\">end<\/span>\r\n\r\n  <span class=\"k\">def<\/span> <span class=\"nf\">new<\/span>\r\n<span class=\"hll\">    <span class=\"vi\">@user<\/span> <span class=\"o\">=<\/span> <span class=\"no\">User<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span>\r\n<\/span>  <span class=\"k\">end<\/span>\r\n<span class=\"k\">end<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<div class=\"heading\"><span class=\"description\">\u65b0\u898f\u30e6\u30fc\u30b6\u30fc\u306e\u305f\u3081\u306e\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30d5\u30a9\u30fc\u30e0<\/span><\/div>\n<div class=\"heading\"><span class=\"description\"><strong><code class=\"filepath\">app\/views\/users\/new.html.erb<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"cp\">&lt;%<\/span> <span class=\"n\">provide<\/span><span class=\"p\">(<\/span><span class=\"ss\">:title<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'Sign up'<\/span><span class=\"p\">)<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<span class=\"p\">&lt;<\/span><span class=\"nt\">h1<\/span><span class=\"p\">&gt;<\/span>Sign up<span class=\"p\">&lt;\/<\/span><span class=\"nt\">h1<\/span><span class=\"p\">&gt;<\/span>\r\n\r\n<span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"row\"<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"col-md-6 col-md-offset-3\"<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">form_for<\/span><span class=\"p\">(<\/span><span class=\"vi\">@user<\/span><span class=\"p\">)<\/span> <span class=\"k\">do<\/span> <span class=\"o\">|<\/span><span class=\"n\">f<\/span><span class=\"o\">|<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">label<\/span> <span class=\"ss\">:name<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">text_field<\/span> <span class=\"ss\">:name<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">label<\/span> <span class=\"ss\">:email<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">email_field<\/span> <span class=\"ss\">:email<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">label<\/span> <span class=\"ss\">:password<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">password_field<\/span> <span class=\"ss\">:password<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">label<\/span> <span class=\"ss\">:password_confirmation<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"Confirmation\"<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">password_field<\/span> <span class=\"ss\">:password_confirmation<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">submit<\/span> <span class=\"s2\">\"Create my account\"<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"btn btn-primary\"<\/span> <span class=\"cp\">%&gt;<\/span>\r\n    <span class=\"cp\">&lt;%<\/span> <span class=\"k\">end<\/span> <span class=\"cp\">%&gt;<\/span>\r\n  <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n<span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<div class=\"heading\"><span class=\"description\">\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30d5\u30a9\u30fc\u30e0\u306eCSS<\/span><\/div>\n<div class=\"heading\"><span class=\"description\"><strong><code class=\"filepath\">app\/assets\/stylesheets\/custom.scss<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"nc\">.<\/span>\r\n<span class=\"nc\">.<\/span>\r\n<span class=\"nc\">.<\/span>\r\n<span class=\"o\">\/*<\/span> <span class=\"nt\">forms<\/span> <span class=\"o\">*\/<\/span>\r\n\r\n<span class=\"nt\">input<\/span><span class=\"o\">,<\/span> <span class=\"nt\">textarea<\/span><span class=\"o\">,<\/span> <span class=\"nt\">select<\/span><span class=\"o\">,<\/span> <span class=\"nc\">.uneditable-input<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nt\">border<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">1px<\/span> <span class=\"nt\">solid<\/span> <span class=\"nn\">#bbb<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"nt\">width<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">100<\/span><span class=\"err\">%<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"nt\">margin-bottom<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">15px<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"o\">@<\/span><span class=\"nt\">include<\/span> <span class=\"nt\">box_sizing<\/span><span class=\"o\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nt\">input<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nt\">height<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">auto<\/span> <span class=\"o\">!<\/span><span class=\"nt\">important<\/span><span class=\"o\">;<\/span>\r\n<span class=\"p\">}<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<h3>\u6f14\u7fd2<\/h3>\n<p>\u8a66\u3057\u306b\u3001<a class=\"hyperref\" href=\"https:\/\/railstutorial.jp\/chapters\/sign_up?version=5.1#code-signup_form\">\u30ea\u30b9\u30c8\u00a0<span class=\"ref\">7.15<\/span><\/a>\u306b\u3042\u308b<code>:name<\/code>\u3092<code>:nome<\/code>\u306b\u7f6e\u304d\u63db\u3048\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u3069\u3093\u306a\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u304c\u8868\u793a\u3055\u308c\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u304b?<span id=\"ex-7224ab\" class=\"exercise\"><\/span><\/p>\n<pre><strong>undefined method `nome'<\/strong><\/pre>\n<p>\u8a66\u3057\u306b\u3001\u30d6\u30ed\u30c3\u30af\u306e\u5909\u6570<code>f<\/code>\u3092\u3059\u3079\u3066<code>foobar<\/code>\u306b\u7f6e\u304d\u63db\u3048\u3066\u307f\u3066\u3001\u7d50\u679c\u304c\u5909\u308f\u3089\u306a\u3044\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002\u78ba\u304b\u306b\u7d50\u679c\u306f\u5909\u308f\u308a\u307e\u305b\u3093\u304c\u3001\u5909\u6570\u540d\u3092<code>foobar<\/code>\u3068\u3059\u308b\u306e\u306f\u3042\u307e\u308a\u826f\u3044\u5909\u66f4\u3067\u306f\u306a\u3055\u305d\u3046\u3067\u3059\u306d\u3002\u305d\u306e\u7406\u7531\u306b\u3064\u3044\u3066\u8003\u3048\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<p>\u5909\u6570f\u306f \u201cform\u201d \u306ef\u3092\u4f7f\u7528\u3057\u3066\u3044\u308b\u3002&#8221;f.label&#8221;\u7b49\u304cHTML\u30d5\u30a9\u30fc\u30e0\u8981\u7d20\u306b\u5bfe\u5fdc\u3059\u308b\u3053\u3068\u304c\u308f\u304b\u308b\u3088\u3046\u306b\u3059\u308b\u3002&#8221;foobar&#8221;\u306f\u30e1\u30bf\u69cb\u6587\u5909\u6570\uff08\u610f\u5473\u3092\u6301\u305f\u306a\u3044\u540d\u524d\uff09\u3068\u3057\u3066\u8a8d\u8b58\u3055\u308c\u308b\u305f\u3081\u9069\u3055\u306a\u3044\u3002\u307b\u304b\u306fhoge\u3068\u304bhuga\u3068\u304b<\/p>\n<h3><span class=\"number\">7.2.2\u00a0<\/span>\u30d5\u30a9\u30fc\u30e0HTML<\/h3>\n<p>\u3053\u308c\u307e\u3067\u898b\u3066\u304d\u305f\u6b21\u306e\u3088\u3046\u306a\u30b3\u30fc\u30c9 (\u30de\u30b9\u30a2\u30b5\u30a4\u30f3\u30e1\u30f3\u30c8\u3068\u547c\u3073\u307e\u3059) \u306f\u3001<\/p>\n<pre><strong>@user = User.new(params[:user])<\/strong><\/pre>\n<p>\u5b9f\u969b\u306b\u306f\u3053\u306e\u3088\u3046\u306a\u30b3\u30fc\u30c9\u3068\u307b\u307c\u540c\u3058\u3067\u3042\u308b\u3001\u3068\u3044\u3046\u3053\u3068\u3067\u3059\u3002<\/p>\n<pre><strong>@user = User.new(name: \"Foo Bar\", email: \"foo@invalid\",<\/strong>\r\n<strong>password: \"foo\", password_confirmation: \"bar\")<\/strong><\/pre>\n<h3>\u6f14\u7fd2<\/h3>\n<p>\/signup?admin=1 \u306b\u30a2\u30af\u30bb\u30b9\u3057\u3001params\u306e\u4e2d\u306badmin\u5c5e\u6027\u304c\u542b\u307e\u308c\u3066\u3044\u308b\u3053\u3068\u3092\u30c7\u30d0\u30c3\u30b0\u60c5\u5831\u304b\u3089\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<p>Sass\u306e@extend\u95a2\u6570\u3092\u4f7f\u3063\u3066Bootstrap\u306ehas-error\u3068\u3044\u3046CSS\u30af\u30e9\u30b9\u3092\u9069\u7528\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n<pre><strong>#error_explanation {<\/strong>\r\n<strong>  color: red;<\/strong>\r\n<strong>\r\n  ul {<\/strong>\r\n<strong>    color: red;<\/strong>\r\n<strong>    margin: 0 0 30px 0;<\/strong>\r\n<strong>  }<\/strong>\r\n<strong> }<\/strong>\r\n\r\n<strong>.field_with_errors {<\/strong>\r\n<strong>   @extend .has-error;\r\n<\/strong>\r\n<strong> .form-control {<\/strong>\r\n<strong>    color: $state-danger-text;<\/strong>\r\n<strong>  }<\/strong>\r\n<strong>}<\/strong><\/pre>\n<p><strong>\u6f14\u7fd2<\/strong><\/p>\n<p>1:\u30ea\u30b9\u30c8 7.20\u3067\u5b9f\u88c5\u3057\u305f\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u306b\u5bfe\u3059\u308b\u30c6\u30b9\u30c8\u3092\u66f8\u3044\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002\u3069\u306e\u304f\u3089\u3044\u7d30\u304b\u304f\u30c6\u30b9\u30c8\u3059\u308b\u304b\u306f\u304a\u4efb\u305b\u3057\u307e\u3059\u3002\u30ea\u30b9\u30c8 7.25\u306b\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3092\u7528\u610f\u3057\u3066\u304a\u3044\u305f\u306e\u3067\u3001\u53c2\u8003\u306b\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre class=\"code lang-ruby\" data-lang=\"ruby\" data-unlink=\"\"><strong>users_signup_test.rb\r\n\r\n<span class=\"synPreProc\">require<\/span> <span class=\"synSpecial\">'<\/span><span class=\"synConstant\">test_helper<\/span><span class=\"synSpecial\">'<\/span>\r\n\r\n<span class=\"synPreProc\">class<\/span> <span class=\"synType\">UsersSignupTest<\/span> &lt; <span class=\"synType\">ActionDispatch<\/span>::<span class=\"synType\">IntegrationTest<\/span>\r\n\r\n  test <span class=\"synSpecial\">\"<\/span><span class=\"synConstant\">invalid signup information<\/span><span class=\"synSpecial\">\"<\/span> <span class=\"synStatement\">do<\/span>\r\n    get signup_path\r\n\r\n\uff08\u4e2d\u7565\uff09\r\n\r\n    assert_template <span class=\"synSpecial\">'<\/span><span class=\"synConstant\">users\/new<\/span><span class=\"synSpecial\">'<\/span>\r\n    assert_select <span class=\"synSpecial\">'<\/span><span class=\"synConstant\">div#error_explanation<\/span><span class=\"synSpecial\">'<\/span>\r\n    assert_select <span class=\"synSpecial\">'<\/span><span class=\"synConstant\">div.alert<\/span><span class=\"synSpecial\">'<\/span>   \r\n  <span class=\"synStatement\">end<\/span>\r\n<span class=\"synPreProc\">end<\/span><\/strong><\/pre>\n<p>2:\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30d5\u30a9\u30fc\u30e0\u306eURL\u306f \/signup \u3067\u3059\u304c\u3001\u7121\u52b9\u306a\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30c7\u30fc\u30bf\u3092\u9001\u4ed8\u3059\u308b\u3068URL\u304c \/users \u306b\u5909\u308f\u3063\u3066\u3057\u307e\u3044\u307e\u3059\u3002\u3053\u308c\u306f\u30ea\u30b9\u30c8 5.43\u3067\u8ffd\u52a0\u3057\u305f\u540d\u524d\u4ed8\u304d\u30eb\u30fc\u30c8 (\/signup) \u3068\u3001RESTful\u306a\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0 (\u30ea\u30b9\u30c8 7.3) \u306e\u30c7\u30d5\u30a9\u30eb\u30c8\u8a2d\u5b9a\u3068\u306e\u5dee\u7570\u306b\u3088\u3063\u3066\u751f\u3058\u305f\u7d50\u679c\u3067\u3059\u3002\u30ea\u30b9\u30c8 7.26\u3068\u30ea\u30b9\u30c8 7.27\u306e\u5185\u5bb9\u3092\u53c2\u8003\u306b\u3001\u3053\u306e\u554f\u984c\u3092\u89e3\u6c7a\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002\u3046\u307e\u304f\u3044\u3051\u3070\u3069\u3061\u3089\u306eURL\u3082 \/signup \u306b\u306a\u308b\u306f\u305a\u3067\u3059\u3002\u3042\u308c\u3001\u3067\u3082\u30c6\u30b9\u30c8\u306f green\u306e\u307e\u307e\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u306d&#8230;\u3001\u306a\u305c\u3067\u3057\u3087\u3046\u304b? (\u8003\u3048\u3066\u307f\u3066\u304f\u3060\u3055\u3044)<\/p>\n<p>\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u306e\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u306b<code class=\"tt\">POST<\/code>\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u8ffd\u52a0\u3059\u308b<strong><code class=\"filepath\">config\/routes.rb<\/code><\/strong><\/p>\n<pre><strong><span class=\"hll\">  <span class=\"n\">post<\/span> <span class=\"s1\">'\/signup'<\/span><span class=\"p\">,<\/span>  <span class=\"ss\">to<\/span><span class=\"p\">:<\/span> <span class=\"s1\">'users#create'<\/span><\/span><\/strong><\/pre>\n<div class=\"heading\">\u00a0<span class=\"description\">\/signup \u306b\u5bfe\u3057\u3066\u9001\u4fe1\u3059\u308b<code class=\"filepath\">app\/views\/users\/new.html.erb<\/code><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"cp\">&lt;%<\/span> <span class=\"n\">provide<\/span><span class=\"p\">(<\/span><span class=\"ss\">:title<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'Sign up'<\/span><span class=\"p\">)<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<span class=\"p\">&lt;<\/span><span class=\"nt\">h1<\/span><span class=\"p\">&gt;<\/span>Sign up<span class=\"p\">&lt;\/<\/span><span class=\"nt\">h1<\/span><span class=\"p\">&gt;<\/span>\r\n\r\n<span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"row\"<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"col-md-6 col-md-offset-3\"<\/span><span class=\"p\">&gt;<\/span>\r\n<span class=\"hll\">    <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">form_for<\/span><span class=\"p\">(<\/span><span class=\"vi\">@user<\/span><span class=\"p\">,<\/span> <span class=\"ss\">url<\/span><span class=\"p\">:<\/span> <span class=\"n\">signup_path<\/span><span class=\"p\">)<\/span> <span class=\"k\">do<\/span> <span class=\"o\">|<\/span><span class=\"n\">f<\/span><span class=\"o\">|<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<\/span>      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">render<\/span> <span class=\"s1\">'shared\/error_messages'<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">label<\/span> <span class=\"ss\">:name<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">text_field<\/span> <span class=\"ss\">:name<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s1\">'form-control'<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">label<\/span> <span class=\"ss\">:email<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">email_field<\/span> <span class=\"ss\">:email<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s1\">'form-control'<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">label<\/span> <span class=\"ss\">:password<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">password_field<\/span> <span class=\"ss\">:password<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s1\">'form-control'<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">label<\/span> <span class=\"ss\">:password_confirmation<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"Confirmation\"<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">password_field<\/span> <span class=\"ss\">:password_confirmation<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s1\">'form-control'<\/span> <span class=\"cp\">%&gt;<\/span>\r\n\r\n      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">f<\/span><span class=\"o\">.<\/span><span class=\"n\">submit<\/span> <span class=\"s2\">\"Create my account\"<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"btn btn-primary\"<\/span> <span class=\"cp\">%&gt;<\/span>\r\n    <span class=\"cp\">&lt;%<\/span> <span class=\"k\">end<\/span> <span class=\"cp\">%&gt;<\/span>\r\n  <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n<span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<p>\u3044\u305a\u308c\u306eURL\u3082 \/signup \u3068\u306a\u308b\u3002<\/p>\n<p>3:\u30ea\u30b9\u30c8 7.25\u306epost\u90e8\u5206\u3092\u5909\u66f4\u3057\u3066\u3001\u5148\u307b\u3069\u306e\u6f14\u7fd2\u8ab2\u984c\u3067\u4f5c\u3063\u305f\u65b0\u3057\u3044URL (\/signup) \u306b\u5408\u308f\u305b\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u307e\u305f\u3001\u30c6\u30b9\u30c8\u304c green\u306e\u307e\u307e\u306b\u306a\u3063\u3066\u3044\u308b\u70b9\u3082\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre class=\"code lang-ruby\" data-lang=\"ruby\" data-unlink=\"\"><strong>users_signup_test.rb\r\n\r\n<span class=\"synPreProc\">require<\/span> <span class=\"synSpecial\">'<\/span><span class=\"synConstant\">test_helper<\/span><span class=\"synSpecial\">'<\/span>\r\n\r\n<span class=\"synPreProc\">class<\/span> <span class=\"synType\">UsersSignupTest<\/span> &lt; <span class=\"synType\">ActionDispatch<\/span>::<span class=\"synType\">IntegrationTest<\/span>\r\n\r\n  test <span class=\"synSpecial\">\"<\/span><span class=\"synConstant\">invalid signup information<\/span><span class=\"synSpecial\">\"<\/span> <span class=\"synStatement\">do<\/span>\r\n    get signup_path\r\n    assert_no_difference <span class=\"synSpecial\">'<\/span><span class=\"synConstant\">User.count<\/span><span class=\"synSpecial\">'<\/span> <span class=\"synStatement\">do<\/span>\r\n      post signup_path, <span class=\"synConstant\">params<\/span>: { <span class=\"synConstant\">user<\/span>: { <span class=\"synConstant\">name<\/span>:  <span class=\"synSpecial\">\"\"<\/span>,\r\n\uff08\u5f8c\u7565\uff09<\/strong><\/pre>\n<p>4:\u30ea\u30b9\u30c8 7.27\u306e\u30d5\u30a9\u30fc\u30e0\u3092\u4ee5\u524d\u306e\u72b6\u614b\u306b\u623b\u3057\u3066\u307f\u3066\u3001\u30c6\u30b9\u30c8\u304c\u3084\u306f\u308a green\u306b\u306a\u3063\u3066\u3044\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u3053\u308c\u306f\u554f\u984c\u3067\u3059! \u306a\u305c\u306a\u3089\u3001\u73fe\u5728post\u304c\u9001\u4fe1\u3055\u308c\u3066\u3044\u308bURL\u306f\u6b63\u3057\u304f\u306a\u3044\u306e\u3067\u3059\u304b\u3089\u3002assert_select\u3092\u4f7f\u3063\u305f\u30c6\u30b9\u30c8\u3092\u30ea\u30b9\u30c8 7.25\u306b\u8ffd\u52a0\u3057\u3001\u3053\u306e\u30d0\u30b0\u3092\u691c\u77e5\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u3066\u307f\u307e\u3057\u3087\u3046 (\u30c6\u30b9\u30c8\u3092\u8ffd\u52a0\u3057\u3066 red\u306b\u306a\u308c\u3070\u6210\u529f\u3067\u3059)\u3002\u305d\u306e\u5f8c\u3001\u5909\u66f4\u5f8c\u306e\u30d5\u30a9\u30fc\u30e0 (\u30ea\u30b9\u30c8 7.27) \u306b\u623b\u3057\u3066\u307f\u3066\u3001\u30c6\u30b9\u30c8\u304c green \u306b\u306a\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u30d2\u30f3\u30c8: \u30d5\u30a9\u30fc\u30e0\u304b\u3089\u9001\u4fe1\u3057\u3066\u30c6\u30b9\u30c8\u3059\u308b\u306e\u3067\u306f\u306a\u304f\u3001&#8217;form[action=&#8221;\/signup&#8221;]&#8217;\u3068\u3044\u3046\u90e8\u5206\u304c\u5b58\u5728\u3059\u308b\u304b\u3069\u3046\u304b\u306b\u7740\u76ee\u3057\u3066\u30c6\u30b9\u30c8\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<p>\u30ea\u30b9\u30c8 7.27\u306e\u30d5\u30a9\u30fc\u30e0\u3092\u4ee5\u524d\u306e\u72b6\u614b (\u30ea\u30b9\u30c8 7.20) \u306b\u623b\u3057\u3066\u3082\u30c6\u30b9\u30c8\u306fGREEN\u3002<\/p>\n<h3><span class=\"number\">7.4.2\u00a0<\/span>flash<\/h3>\n<p>flash\u3068\u3044\u3046\u7279\u6b8a\u306a\u5909\u6570\u3092\u4f7f\u3044\u307e\u3059\u3002\u3053\u306e\u5909\u6570\u306f\u30cf\u30c3\u30b7\u30e5\u306e\u3088\u3046\u306b\u6271\u3044\u307e\u3059\u3002Rails\u306e\u4e00\u822c\u7684\u306a\u6163\u7fd2\u306b\u5023\u3063\u3066\u3001:success\u3068\u3044\u3046\u30ad\u30fc\u306b\u306f\u6210\u529f\u6642\u306e\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u4ee3\u5165\u3059\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002<\/p>\n<h3>\u6f14\u7fd2<\/h3>\n<p>1:\u30b3\u30f3\u30bd\u30fc\u30eb\u306b\u79fb\u308a\u3001\u6587\u5b57\u5217\u5185\u306e\u5f0f\u5c55\u958b (4.2.2) \u3067\u30b7\u30f3\u30dc\u30eb\u3092\u547c\u3073\u51fa\u3057\u3066\u307f\u307e\u3057\u3087\u3046<br \/>\n\u4f8b\u3048\u3070&#8221;#{:success}&#8221;\u3068\u3044\u3063\u305f\u30b3\u30fc\u30c9\u3092\u5b9f\u884c\u3059\u308b\u3068\u3001\u3069\u3093\u306a\u5024\u304c\u8fd4\u3063\u3066\u304d\u307e\u3059\u304b?<\/p>\n<pre><strong>\"#{:success}\"<\/strong>\r\n<strong>=&gt; \"success\"<\/strong><\/pre>\n<p>2:\u5148\u307b\u3069\u306e\u6f14\u7fd2\u3067\u8a66\u3057\u305f\u7d50\u679c\u3092\u53c2\u8003\u306b\u3001\u30ea\u30b9\u30c8 7.30\u306eflash\u306f\u3069\u306e\u3088\u3046\u306a\u7d50\u679c\u306b\u306a\u308b\u304b\u8003\u3048\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre><strong>flash = { success: \"It worked!\", danger: \"It failed.\" }<\/strong>\r\n<strong>\"#{flash[:success]}\"<\/strong>\r\n<strong>=&gt; \"It worked!\"<\/strong>\r\n<strong>&gt;&gt; \"#{flash[:danger]}\"<\/strong>\r\n<strong>=&gt; \"It failed.\"<\/strong><\/pre>\n<h2>\u6f14\u7fd2<\/h2>\n<h3>1:Rails\u30b3\u30f3\u30bd\u30fc\u30eb\u3092\u4f7f\u3063\u3066\u3001\u65b0\u3057\u3044\u30e6\u30fc\u30b6\u30fc\u304c\u672c\u5f53\u306b\u4f5c\u6210\u3055\u308c\u305f\u306e\u304b\u3082\u3046\u4e00\u5ea6\u30c1\u30a7\u30c3\u30af\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u7d50\u679c\u306f\u3001\u30ea\u30b9\u30c8 7.32\u306e\u3088\u3046\u306b\u306a\u308b\u306f\u305a\u3067\u3059\u3002<\/h3>\n<p>\u52d5\u4f5c\u78ba\u8a8d\u3059\u308b\u3060\u3051<\/p>\n<h3>2:\u81ea\u5206\u306e\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9\u3067\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u3092\u8a66\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u65e2\u306bGravatar\u306b\u767b\u9332\u3057\u3066\u3044\u308b\u5834\u5408\u3001\u9069\u5207\u306a\u753b\u50cf\u304c\u8868\u793a\u3055\u308c\u3066\u3044\u308b\u304b\u78ba\u8a8d\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/h3>\n<p>\u52d5\u4f5c\u78ba\u8a8d\u3059\u308b\u3060\u3051<\/p>\n<h3>\u6f14\u7fd2<\/h3>\n<p>1:\u5b9f\u88c5\u3057\u305fflash\u306b\u5bfe\u3059\u308b\u30c6\u30b9\u30c8\u3092\u66f8\u3044\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002\u3069\u306e\u304f\u3089\u3044\u7d30\u304b\u304f\u30c6\u30b9\u30c8\u3059\u308b<br \/>\n\u304b\u306f\u304a\u4efb\u305b\u3002\u30ea\u30b9\u30c8 7.34\u306b\u6700\u5c0f\u9650\u306e\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3092\u7528\u610f\u3057\u3066\u304a\u3044\u305f\u306e\u3067\u3001\u53c2\u8003\u306b\u3057\u3066\u304f\u3060\u3055\u3044 (FILL_IN\u306e\u90e8\u5206\u3092\u9069\u5207\u306a\u30b3\u30fc\u30c9\u306b\u7f6e\u304d\u63db\u3048\u308b\u3068\u5b8c\u6210\u3057\u307e\u3059)\u3002<br \/>\n\u30c6\u30ad\u30b9\u30c8\u306b\u5bfe\u3059\u308b\u30c6\u30b9\u30c8\u306f\u58ca\u308c\u3084\u3059\u3044\u3067\u3059\u3002\u6587\u91cf\u306e\u5c11\u306a\u3044flash\u306e\u30ad\u30fc\u3067\u3042\u3063\u3066\u3082\u3001\u305d\u308c\u306f\u540c\u3058\u3067\u3059\u3002\u7b46\u8005\u306e\u5834\u5408\u3001flash\u304c\u7a7a\u3067\u306a\u3044\u304b\u3092\u30c6\u30b9\u30c8\u3059\u308b\u3060\u3051\u306e\u5834\u5408\u304c\u591a\u3044\u3067\u3059\u3002<\/p>\n<pre class=\"code lang-ruby\" data-lang=\"ruby\" data-unlink=\"\"><strong>users_signup_test.rb\r\n\r\n<span class=\"synPreProc\">require<\/span> <span class=\"synSpecial\">'<\/span><span class=\"synConstant\">test_helper<\/span><span class=\"synSpecial\">'<\/span>\r\n<span class=\"synPreProc\">class<\/span> <span class=\"synType\">UsersSignupTest<\/span> &lt; <span class=\"synType\">ActionDispatch<\/span>::<span class=\"synType\">IntegrationTest<\/span>\r\n\uff08\u4e2d\u7565\uff09\r\n  test <span class=\"synSpecial\">\"<\/span><span class=\"synConstant\">valid signup information<\/span><span class=\"synSpecial\">\"<\/span> <span class=\"synStatement\">do<\/span>\r\n\uff08\u4e2d\u7565\uff09\r\n    assert_not flash.empty?    \r\n  <span class=\"synStatement\">end<\/span>  \r\n<span class=\"synPreProc\">end<\/span><\/strong><\/pre>\n<p>2:\u672c\u6587\u4e2d\u3067\u3082\u6307\u6458\u3057\u307e\u3057\u305f\u304c\u3001flash\u7528\u306eHTML\u306f\u8aad\u307f\u306b\u304f\u3044\u3067\u3059\u3002\u3088\u308a\u8aad\u307f\u3084\u3059\u304f\u3057\u305f\u30ea\u30b9\u30c8 7.35\u306e\u30b3\u30fc\u30c9\u306b\u5909\u66f4\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u5909\u66f4\u304c\u7d42\u308f\u3063\u305f\u3089\u30c6\u30b9\u30c8\u30b9\u30a4\u30fc\u30c8\u3092\u5b9f\u884c\u3057\u3001\u6b63\u5e38\u306b\u52d5\u4f5c\u3059\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u306a\u304a\u3001\u3053\u306e\u30b3\u30fc\u30c9\u3067\u306f\u3001Rails\u306econtent_tag\u3068\u3044\u3046\u30d8\u30eb\u30d1\u30fc\u3092\u4f7f\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<div class=\"heading\"><strong><span class=\"description\"><code class=\"filepath\">app\/views\/layouts\/application.html.erb<\/code><\/span><\/strong><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"cp\">&lt;!DOCTYPE html&gt;<\/span>\r\n<span class=\"p\">&lt;<\/span><span class=\"nt\">html<\/span><span class=\"p\">&gt;<\/span>\r\n      .\r\n      .\r\n      .\r\n      <span class=\"cp\">&lt;%<\/span> <span class=\"n\">flash<\/span><span class=\"o\">.<\/span><span class=\"n\">each<\/span> <span class=\"k\">do<\/span> <span class=\"o\">|<\/span><span class=\"n\">message_type<\/span><span class=\"p\">,<\/span> <span class=\"n\">message<\/span><span class=\"o\">|<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<span class=\"hll\">        <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">content_tag<\/span><span class=\"p\">(<\/span><span class=\"ss\">:div<\/span><span class=\"p\">,<\/span> <span class=\"n\">message<\/span><span class=\"p\">,<\/span> <span class=\"ss\">class<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"alert alert-<\/span><span class=\"si\">#{<\/span><span class=\"n\">message_type<\/span><span class=\"si\">}<\/span><span class=\"s2\">\"<\/span><span class=\"p\">)<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<\/span>      <span class=\"cp\">&lt;%<\/span> <span class=\"k\">end<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      .\r\n      .\r\n      .\r\n<span class=\"p\">&lt;\/<\/span><span class=\"nt\">html<\/span><span class=\"p\">&gt;<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<p>3:\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u306e\u884c\u3092\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3059\u308b\u3068\u3001\u30c6\u30b9\u30c8\u304c\u5931\u6557\u3059\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<div class=\"heading\"><span class=\"description\">\u4fdd\u5b58\u3068\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u3092\u884c\u3046\u3001user\u306e<code>create<\/code>\u30a2\u30af\u30b7\u30e7\u30f3<strong><code class=\"filepath\">app\/controllers\/users_controller.rb<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"k\">class<\/span> <span class=\"nc\">UsersController<\/span> <span class=\"o\">&lt;<\/span> <span class=\"no\">ApplicationController<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"k\">def<\/span> <span class=\"nf\">create<\/span>\r\n    <span class=\"vi\">@user<\/span> <span class=\"o\">=<\/span> <span class=\"no\">User<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"n\">user_params<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">if<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.<\/span><span class=\"n\">save<\/span>\r\n<span class=\"hll\">      #<span class=\"n\">redirect_to<\/span> <span class=\"vi\">@user<\/span>\r\n<\/span>    <span class=\"k\">else<\/span>\r\n      <span class=\"n\">render<\/span> <span class=\"s1\">'new'<\/span>\r\n    <span class=\"k\">end<\/span>\r\n  <span class=\"k\">end<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<p>4:\u30ea\u30b9\u30c8 7.28\u3067\u3001@user.save\u306e\u90e8\u5206\u3092false\u306b\u7f6e\u304d\u63db\u3048\u305f\u3068\u3057\u307e\u3057\u3087\u3046 (\u30d0\u30b0\u3092\u57cb\u3081\u8fbc\u3093\u3067\u3057\u307e\u3063\u305f\u3068\u4eee\u5b9a\u3057\u3066\u304f\u3060\u3055\u3044)\u3002\u3053\u306e\u3068\u304d\u3001assert_difference\u306e\u30c6\u30b9\u30c8\u3067\u306f\u3069\u306e\u3088\u3046\u306b\u3057\u3066\u3053\u306e\u30d0\u30b0\u3092\u691c\u77e5\u3059\u308b\u3067\u3057\u3087\u3046\u304b? \u30c6\u30b9\u30c8\u30b3\u30fc\u30c9\u3092\u8ffd\u3063\u3066\u8003\u3048\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<div class=\"heading\"><span class=\"description\">\u4fdd\u5b58\u3068\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u3092\u884c\u3046\u3001user\u306e<code>create<\/code>\u30a2\u30af\u30b7\u30e7\u30f3<strong><code class=\"filepath\">app\/controllers\/users_controller.rb<\/code><\/strong><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre><strong><span class=\"k\">class<\/span> <span class=\"nc\">UsersController<\/span> <span class=\"o\">&lt;<\/span> <span class=\"no\">ApplicationController<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"k\">def<\/span> <span class=\"nf\">create<\/span>\r\n    <span class=\"vi\">@user<\/span> <span class=\"o\">=<\/span> <span class=\"no\">User<\/span><span class=\"o\">.<\/span><span class=\"n\">new<\/span><span class=\"p\">(<\/span><span class=\"n\">user_params<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">if<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.false\r\n<\/span>\u00a0<span class=\"hll\">     <span class=\"n\">redirect_to<\/span> <span class=\"vi\">@user<\/span>\r\n<\/span>    <span class=\"k\">else<\/span>\r\n      <span class=\"n\">render<\/span> <span class=\"s1\">'new'<\/span>\r\n    <span class=\"k\">end<\/span>\r\n  <span class=\"k\">end<\/span>\r\n\r\n  <span class=\"kp\">private<\/span>\r\n\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">user_params<\/span>\r\n      <span class=\"n\">params<\/span><span class=\"o\">.<\/span><span class=\"n\">require<\/span><span class=\"p\">(<\/span><span class=\"ss\">:user<\/span><span class=\"p\">)<\/span><span class=\"o\">.<\/span><span class=\"n\">permit<\/span><span class=\"p\">(<\/span><span class=\"ss\">:name<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:email<\/span><span class=\"p\">,<\/span> <span class=\"ss\">:password<\/span><span class=\"p\">,<\/span>\r\n                                   <span class=\"ss\">:password_confirmation<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">end<\/span>\r\n<span class=\"k\">end<\/span><\/strong><\/pre>\n<\/div>\n<\/div>\n<h3>7\u7ae0\u306e\u307e\u3068\u3081<\/h3>\n<h4>1\uff1adebug\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3046\u3053\u3068\u3067\u3001\u5f79\u7acb\u3064\u30c7\u30d0\u30c3\u30b0\u60c5\u5831\u3092\u8868\u793a\u3067\u304d\u308b<\/h4>\n<h4>2\uff1aSass\u306emixin\u6a5f\u80fd\u3092\u4f7f\u3046\u3068\u3001CSS\u306e\u30eb\u30fc\u30eb\u3092\u307e\u3068\u3081\u305f\u308a\u4ed6\u306e\u5834\u6240\u3067\u518d\u5229\u7528\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b<\/h4>\n<h4>3\uff1aRails\u306b\u306f\u6a19\u6e96\u30673\u3064\u74b0\u5883\u304c\u5099\u308f\u3063\u3066\u304a\u308a\u3001\u305d\u308c\u305e\u308c\u958b\u767a\u74b0\u5883 (development)\u3001\u30c6\u30b9\u30c8\u74b0\u5883 (test)\u3001\u672c\u756a\u74b0\u5883 (production)\u3068\u547c\u3076<\/h4>\n<h4>4\uff1a\u6a19\u6e96\u7684\u306aRESTful\u306aURL\u3092\u901a\u3057\u3066\u3001\u30e6\u30fc\u30b6\u30fc\u60c5\u5831\u3092\u30ea\u30bd\u30fc\u30b9\u3068\u3057\u3066\u6271\u3048\u308b\u3088\u3046\u306b\u306a\u3063\u305f<\/h4>\n<h4>5\uff1aGravatar\u3092\u4f7f\u3046\u3068\u3001\u30e6\u30fc\u30b6\u30fc\u306e\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u50cf\u3092\u7c21\u5358\u306b\u8868\u793a\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b<\/h4>\n<h4>6\uff1a\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u306b\u5931\u6557\u3057\u305f\u5834\u5408\u306fnew\u30d3\u30e5\u30fc\u3092\u518d\u63cf\u753b\u3059\u308b\u3088\u3046\u306b\u3057\u305f\u3002\u305d\u306e\u969b\u3001Active Record\u304c\u81ea\u52d5\u7684\u306b\u691c\u77e5\u3057\u305f\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u8868\u793a\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u305f<\/h4>\n<h4>7\uff1aflash\u5909\u6570\u3092\u4f7f\u3046\u3068\u3001\u4e00\u6642\u7684\u306a\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u8868\u793a\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b<\/h4>\n<h4>8\uff1a\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u306b\u6210\u529f\u3059\u308b\u3068\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u4e0a\u306b\u30e6\u30fc\u30b6\u30fc\u304c\u8ffd\u52a0\u3001\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u30da\u30fc\u30b8\u306b\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u3001\u30a6\u30a7\u30eb\u30ab\u30e0\u30e1\u30c3\u30bb\u30fc\u30b8\u306e\u8868\u793a\u3068\u3044\u3063\u305f\u9806\u3067\u51e6\u7406\u304c\u9032\u3080<\/h4>\n<h4>9\uff1a\u7d71\u5408\u30c6\u30b9\u30c8\u3092\u4f7f\u3046\u3053\u3068\u3067\u9001\u4fe1\u30d5\u30a9\u30fc\u30e0\u306e\u632f\u308b\u821e\u3044\u3092\u691c\u8a3c\u3057\u305f\u308a\u3001\u30d0\u30b0\u306e\u767a\u751f\u3092\u691c\u77e5\u3057\u305f\u308a\u3067\u304d\u308b<\/h4>\n<h4>10\uff1a\u30bb\u30ad\u30e5\u30a2\u306a\u901a\u4fe1\u3068\u9ad8\u3044\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u78ba\u4fdd\u3059\u308b\u305f\u3081\u306b\u3001\u672c\u756a\u74b0\u5883\u3067\u306fSSL\u3068Puma\u3092\u5c0e\u5165\u3057\u305f<\/h4>\n<p><a href=\"https:\/\/suzutukiblog.com\/index.php\/2021\/04\/19\/rails-tutorial-8\/\">\u305d\u306e8\u306b\u7d9a\u304f<\/a><\/p>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u305d\u306e6\u304b\u3089\u7d9a\u304d\u307e\u3059 7.1.1\u00a0\u30c7\u30d0\u30c3\u30b0\u3068Rails\u74b0\u5883 \u30b5\u30a4\u30c8\u306e\u30ec\u30a4\u30a2\u30a6\u30c8\u306b\u30c7\u30d0\u30c3\u30b0\u60c5\u5831\u3092\u8ffd\u52a0\u3059\u308bapp\/views\/layouts\/application.html.erb &lt;!DOCTYPE html&gt; [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":2764,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"footnotes":""},"categories":[27,13],"tags":[],"class_list":["post-2909","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-programming-note","category-rails"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/posts\/2909","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/comments?post=2909"}],"version-history":[{"count":11,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/posts\/2909\/revisions"}],"predecessor-version":[{"id":4533,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/posts\/2909\/revisions\/4533"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/media\/2764"}],"wp:attachment":[{"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/media?parent=2909"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/categories?post=2909"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/tags?post=2909"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}