回答編集履歴
5
追記
test
CHANGED
@@ -85,3 +85,29 @@
|
|
85
85
|
必要なデータが有り、ちゃんとリレーションが設定できていれば、$employees->first()->deptの結果がログに出力されているはずです。
|
86
86
|
|
87
87
|
私が示したソースのパターン以外にも、色んな値のとり方を試みれば、うまくいかない原因に近づけるかと思います。
|
88
|
+
|
89
|
+
|
90
|
+
|
91
|
+
# 追記2
|
92
|
+
|
93
|
+
[https://github.com/dyoshikawa/teratail-131441](https://github.com/dyoshikawa/teratail-131441)
|
94
|
+
|
95
|
+
|
96
|
+
|
97
|
+
サンプルコード書いてみたのでご参考になればと思います。
|
98
|
+
|
99
|
+
動かす場合は、
|
100
|
+
|
101
|
+
|
102
|
+
|
103
|
+
```
|
104
|
+
|
105
|
+
php artisan migrate
|
106
|
+
|
107
|
+
php artisan db:seed
|
108
|
+
|
109
|
+
```
|
110
|
+
|
111
|
+
|
112
|
+
|
113
|
+
を実行した後、サーバー起動してトップページを見て下さい。
|
4
修正
test
CHANGED
@@ -66,6 +66,8 @@
|
|
66
66
|
|
67
67
|
logger($employees);
|
68
68
|
|
69
|
+
logger($employees->first());
|
70
|
+
|
69
71
|
logger($employees->first()->dept);
|
70
72
|
|
71
73
|
return view('employee.belongsto',compact('employees'));
|
@@ -80,6 +82,6 @@
|
|
80
82
|
|
81
83
|
そうすると、storage/logs/下にlaravel.logが生成されているはずですので、中身を確認して下さい。
|
82
84
|
|
83
|
-
必要なデータが有り、ちゃんとリレーションが設定できていれば、$employees->deptの結果がログに出力されているはずです。
|
85
|
+
必要なデータが有り、ちゃんとリレーションが設定できていれば、$employees->first()->deptの結果がログに出力されているはずです。
|
84
86
|
|
85
87
|
私が示したソースのパターン以外にも、色んな値のとり方を試みれば、うまくいかない原因に近づけるかと思います。
|
3
修正
test
CHANGED
@@ -66,7 +66,7 @@
|
|
66
66
|
|
67
67
|
logger($employees);
|
68
68
|
|
69
|
-
logger($employees->dept);
|
69
|
+
logger($employees->first()->dept);
|
70
70
|
|
71
71
|
return view('employee.belongsto',compact('employees'));
|
72
72
|
|
2
追記
test
CHANGED
@@ -43,3 +43,43 @@
|
|
43
43
|
|
44
44
|
|
45
45
|
こちらのViewで$employeesに値が入っているか確認してみて下さい。
|
46
|
+
|
47
|
+
|
48
|
+
|
49
|
+
# 追記
|
50
|
+
|
51
|
+
Laravelのlogger機能を使ってデバッグしてみて下さい。
|
52
|
+
|
53
|
+
まず、storage/logs/laravel.logを削除して下さい(すでに大量のログがあるはずで、これからのデバッグ結果が見づらいため)。
|
54
|
+
|
55
|
+
続いて、controllerを次のような感じに書いてみて下さい。
|
56
|
+
|
57
|
+
|
58
|
+
|
59
|
+
```
|
60
|
+
|
61
|
+
function index()
|
62
|
+
|
63
|
+
{
|
64
|
+
|
65
|
+
$employees = Employee::all();
|
66
|
+
|
67
|
+
logger($employees);
|
68
|
+
|
69
|
+
logger($employees->dept);
|
70
|
+
|
71
|
+
return view('employee.belongsto',compact('employees'));
|
72
|
+
|
73
|
+
}
|
74
|
+
|
75
|
+
```
|
76
|
+
|
77
|
+
|
78
|
+
|
79
|
+
書き換えたら、ブラウザで問題のページにアクセスし、プログラムを動かして下さい。
|
80
|
+
|
81
|
+
そうすると、storage/logs/下にlaravel.logが生成されているはずですので、中身を確認して下さい。
|
82
|
+
|
83
|
+
必要なデータが有り、ちゃんとリレーションが設定できていれば、$employees->deptの結果がログに出力されているはずです。
|
84
|
+
|
85
|
+
私が示したソースのパターン以外にも、色んな値のとり方を試みれば、うまくいかない原因に近づけるかと思います。
|
1
修正
test
CHANGED
@@ -1,13 +1,45 @@
|
|
1
|
-
|
1
|
+
すみません、最初の回答誤っていたので忘れて下さい。
|
2
2
|
|
3
3
|
|
4
4
|
|
5
|
-
|
5
|
+
まず、
|
6
6
|
|
7
|
+
|
8
|
+
|
9
|
+
```
|
10
|
+
|
11
|
+
function index()
|
12
|
+
|
13
|
+
{
|
14
|
+
|
15
|
+
$employees = Employee::all();
|
16
|
+
|
7
|
-
return view('employee.belongsto',
|
17
|
+
return view('employee.belongsto',compact('employees'));
|
18
|
+
|
19
|
+
}
|
8
20
|
|
9
21
|
```
|
10
22
|
|
11
23
|
|
12
24
|
|
25
|
+
こちらのControllerの段階で$employeesに本当に値が入っているか確認してみて下さい。
|
26
|
+
|
27
|
+
値が入っていたら、
|
28
|
+
|
29
|
+
|
30
|
+
|
31
|
+
```
|
32
|
+
|
33
|
+
@foreach($employees as $employee)
|
34
|
+
|
35
|
+
<p>{{ $employee->dept->dept_name }}</p>
|
36
|
+
|
37
|
+
<p>{{ $employee->name }}</p>
|
38
|
+
|
13
|
-
|
39
|
+
@endforeach
|
40
|
+
|
41
|
+
```
|
42
|
+
|
43
|
+
|
44
|
+
|
45
|
+
こちらのViewで$employeesに値が入っているか確認してみて下さい。
|