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

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

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

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

Blade

Bladeとは、 PHPフレームワークのLaravelで使用することができるテンプレートエンジンです。テンプレートの継承とエスケープ機能を提供します。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

1299閲覧

タスクの状態ラベルの色分けができない

退会済みユーザー

退会済みユーザー

総合スコア0

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

Blade

Bladeとは、 PHPフレームワークのLaravelで使用することができるテンプレートエンジンです。テンプレートの継承とエスケープ機能を提供します。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2021/05/23 09:07

編集2021/05/23 09:17

前提・実現したいこと

タスクの状態ラベルの色分けを実装したいのですが、参考サイトのように書いても実装できません。
こちらの記事を参考にしておリます。

開発環境
Laravel 8.4

##現状
イメージ説明
イメージ説明

「未着手」の文字列を表示させたいのに、label-dangerとかえってきてしまう。

##実現したい内容
イメージ説明
中の文字も未着手、着手中と表示されるように。

該当のソースコード

Task.php

<?php namespace App\Models; use Carbon\Carbon; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Task extends Model { /** * 状態定義 */ const STATUS = [ 1 => [ 'label' => '未着手', 'class' => 'label-danger' ], 2 => [ 'label' => '着手中', 'class' => 'label-info' ], 3 => [ 'label' => '完了', 'class' => '' ], ]; /** * 状態のラベル * @return string */ public function getStatusLabelAttribute() { // 状態値 $status = $this->attributes['status']; // 定義されていなければ空文字を返す if (!isset(self::STATUS[$status])) { return ''; } return self::STATUS[$status]['class']; } /** * 整形した期限日 * @return string */ public function getFormattedDueDateAttribute() { return Carbon::createFromFormat('Y-m-d', $this->attributes['due_date']) ->format('Y/m/d'); } }

index.blade.php

@extends('layout') @section('content') <div class="container"> <div class="row"> <div class="col col-md-4"> <nav class="panel panel-default"> <div class="panel-heading">フォルダ</div> <div class="panel-body"> <a href="{{ route('folders.create') }}" class="btn btn-default btn-block"> フォルダを追加する </a> </div> <div class="list-group"> @foreach($folders as $folder) <a href="{{ route('tasks.index', ['folder' => $folder->id]) }}" class="list-group-item {{ $current_folder_id === $folder->id ? 'active' : '' }}" > {{ $folder->title }} </a> @endforeach </div> </nav> </div> <div class="column col-md-8"> <div class="panel panel-default"> <div class="panel-heading">タスク</div> <div class="panel-body"> <div class="text-right"> <a href="{{ route('tasks.create', ['folder' => $current_folder_id]) }}" class="btn btn-default btn-block"> タスクを追加する </a> </div> </div> <table class="table"> <thead> <tr> <th>タイトル</th> <th>状態</th> <th>期限</th> <th></th> </tr> </thead> <tbody> @foreach($tasks as $task) ーーーーーーーー該当箇所ーーーーーーーーーーーー <tr> <td>{{ $task->title }}</td> <td><span class="label {{ $task->status_class }}">{{ $task->status_label }}</span></td> <td>{{ $task->formatted_due_date }}</td> <td><a href="{{ route('tasks.edit', ['folder' => $task->folder_id, 'task' => $task->id]) }}">編集</a></td> </tr> @endforeach ーーーーーーーー該当箇所ーーーーーーーーーーーー </tbody> </table> </div> </div> </div> </div> @endsection

css

@import url('https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css'); @import url('https://cdnjs.cloudflare.com/ajax/libs/bootflat/2.0.4/css/bootflat.min.css'); body { background-color: #f4f7f8; } .navbar { margin: 2rem 0 2.5rem 0; } .my-navbar { align-items: center; background: #333; display: flex; height: 6rem; justify-content: space-between; padding: 0 2%; margin-bottom: 3rem; } .my-navbar-brand { font-size: 18px; } .my-navbar-brand, .my-navbar-item { color: #8c8c8c; } .my-navbar-brand:hover, a.my-navbar-item:hover { color: #ffffff; } .table td:nth-child(2), .table td:nth-child(3), .table td:nth-child(4) { white-space: nowrap; width: 1px; } .form-control[disabled], .form-control[readonly] { background-color: #fff; }

試したこと

cssで読み込んでいるブートストラップが影響している?
最新のブートストラップのcdnにしてみたがレイアウト崩れる。

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

getStatusLabelAttribute() のreturn文の部分が間違えています

php

1public function getStatusLabelAttribute() 2{ 3 // 状態値 4 $status = $this->attributes['status']; 5 6 // 定義されていなければ空文字を返す 7 if (!isset(self::STATUS[$status])) { 8 return ''; 9 } 10 11 //return self::STATUS[$status]['class']; 12 return self::STATUS[$status]['label']; 13}

投稿2021/05/24 02:36

opop1234

総合スコア26

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

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

退会済みユーザー

退会済みユーザー

2021/05/24 11:55

回答ありがとうございます! ただ、文字列は返されますが(未着手など)状態ラベルのによって色分けがされませんでした。
opop1234

2021/05/24 13:09

getStatusClassAttributeメソッドが定義されてないからだと思います
退会済みユーザー

退会済みユーザー

2021/05/24 13:17

ありがとうございます!無事に実装できました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問