草庐IT

关于 php:在创建动态菜单时需要帮助

codeneng 2023-03-28 原文

Need help in creating dynamic menu

我正在使用 PHP 开发一个网站,这是我第一次尝试动态菜单。

我正在做的是为页面创建了一个表格。

表结构如下:

1
2
3
____________________________________________________________________________
|page_id|title|url|content|menu_title|show_on_navuigation|is_sub|parent_page|
|_______|_____|___|_______|__________|___________________|______|___________|

这里的is_sub表示是否是某个主菜单的下拉菜单。 parent_page 是子菜单的主菜单。

现在,我想要的是,像

我创建了 2 个父页面:

About UsTest

和 2 个子菜单:Test aboutus 和 testsub,

Test aboutus 是 About Us 的 sub,testsub 是 test.

查询和循环实际上应该如何,以便菜单完美呈现。

提前致谢。

这是我的菜单结构:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
<ul>

    <li class='has-sub'><span>About Us</span>
     
<ul>

         
<li>
<span>Corporate Profile</span>
</li>

         <li class='last'><span>Vision & Mission</span>
</li>

     
</ul>

   
</li>

   <li class='has-sub'><span>Business Services</span>
     
<ul>

         
<li>
<span>Recruitment</span>
</li>

         
<li>
<span>Training</span>
</li>

         
<li>
<span>Executive Search</span>
</li>

         
<li>
<span>Payroll</span>
</li>

         <li class='last'><span>Background Verification</span>
</li>

     
</ul>

   
</li>

   <li class='has-sub'><span>Employers</span>
     
<ul>

         
<li>
<span>Enquiry</span>
</li>

         
<li>
<span>Job Description</span>
</li>

         
<li>
<span>Employer Contract</span>
</li>

         <li class='last'><span>Feedback</span>
</li>

     
</ul>

   
</li>

   <li class='has-sub'><span>Job Seeker</span>
     
<ul>

         
<li>
<span>Apply For Job/Register</span>
</li>

         
<li>
<span>Career Tips</span>
</li>

         
<li>
<span>Interview Questions</span>
</li>

         
<li>
<span>Interview Process</span>
</li>

         <li class='last'><span>Corporate Dress</span>
</li>

     
</ul>

   
</li>

   <li class='has-sub'><span>Franchise</span>
     
<ul>

         <li class='last'><span>Franchise Enquiry Form</span>
</li>

     
</ul>

   
</li>

   <li class='last'><span>Contact us</span>
</li>
 


</ul>


<?php
function displayMenu($parent_page_id) {
      $sql ="SELECT * FROM `pages` WHERE `parent_page` = '$parent_page_id'"; // sql
      $result = mysql_query($sql);
      if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
         return true; // exit function
      } // else, continue to rest of function
      echo '
<ul>
'
;
      while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
         echo '
<li>
'
. $result['menu_title'] . ''; // no closing
</li>
 yet
         displayMenu($row['page_id']); // this is the recursive part
         echo '
</li>
'
; // close the
<li>
 from before the recursion
      }
      echo '
</ul>
'
;
}
$get_base_menu = mysql_query("SELECT * FROM pages WHERE parent_page = 0");
while($fetch_base_menu = mysql_fetch_array($get_base_menu))
{
    $parent_page_id = $fetch_base_menu['page_id'];
    displayMenu($parent_page_id);

}

?>

  • 你真的想用 mysql 为菜单做所有这些工作吗?整个站点的菜单通常相同,很少更改。因此,我认为,将其硬编码为 HTML 是有道理的。我认为,如果您要经常更改它,并且如果您正在创建某种"后端"来为您的最终用户提供一种编辑菜单结构的方法,那么将其放入数据库中才有意义。否则,为什么要为此使用数据库?
  • 是的,巴特尔。客户希望将来可以添加更多页面。所以我不得不为页面和菜单创建一个表格
  • @ButtleButkus 这就是我的想法。通常菜单项通常是相同的,除了可能会更改登录/注销和注册/登录的内容。
  • Vishal,因此您的客户可能希望在菜单中创建任意数量的级别,以访问不同的页面。但是他们将如何创建页面?我假设如果他们要处理新页面的编码,他们可以处理向菜单"小部件"添加一些 HTML。
  • Buttle,我在后端创建了一个表单,以便能够创建页面。
  • 我会在一分钟内给你一些答案。
  • 好的,巴特尔。热切地等待答案
  • 实际上,您可以发布您希望 HTML 的样子吗?例如。是使用 ul 的下拉菜单吗?
  • 这是静态结构:
  • <ul>
    \\t<li class='has-sub'><span>关于我们</span>
    <ul>

    <li>
    <span>公司简介</span>
    </li>
    <li class='last'><span>愿景

  • 我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)

    使用参数 "0" 调用函数应该会给你完整的菜单树。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    $trace = array();

    function displayMenu($parent_page_id) {
      $sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
      $result = mysql_query($sql);
      if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
         $trace[] ="Page_id $parent_page_id has no children";
         return true; // exit function
      } // else, continue to rest of function
      echo '
    <ul>
    '
    ;
      while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
         $trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
         echo '
    <li>
    '
    . $row['menu_title'] . ''; // no closing
    </li>
     yet
         displayMenu($row['page_id']); // this is the recursive part
         echo '
    </li>
    '
    ; // close the
    <li>
     from before the recursion
      }
      echo '
    </ul>
    '
    ;
    }

    displayMenu(0); // call function for base level

    var_dump($trace);

    更多信息:

    我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!

    但是,我想我是在另一个网站上找到的,这里:

    http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/

    434511

    我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。

    我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。

  • 我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)

    使用参数 "0" 调用函数应该会给你完整的菜单树。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    $trace = array();

    function displayMenu($parent_page_id) {
      $sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
      $result = mysql_query($sql);
      if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
         $trace[] ="Page_id $parent_page_id has no children";
         return true; // exit function
      } // else, continue to rest of function
      echo '
    <ul>
    '
    ;
      while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
         $trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
         echo '
    <li>
    '
    . $row['menu_title'] . ''; // no closing
    </li>
     yet
         displayMenu($row['page_id']); // this is the recursive part
         echo '
    </li>
    '
    ; // close the
    <li>
     from before the recursion
      }
      echo '
    </ul>
    '
    ;
    }

    displayMenu(0); // call function for base level

    var_dump($trace);

    更多信息:

    我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!

    但是,我想我是在另一个网站上找到的,这里:

    http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/

    434511

    我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。

    我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。

  • 我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)

    使用参数 "0" 调用函数应该会给你完整的菜单树。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    $trace = array();

    function displayMenu($parent_page_id) {
      $sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
      $result = mysql_query($sql);
      if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
         $trace[] ="Page_id $parent_page_id has no children";
         return true; // exit function
      } // else, continue to rest of function
      echo '
    <ul>
    '
    ;
      while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
         $trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
         echo '
    <li>
    '
    . $row['menu_title'] . ''; // no closing
    </li>
     yet
         displayMenu($row['page_id']); // this is the recursive part
         echo '
    </li>
    '
    ; // close the
    <li>
     from before the recursion
      }
      echo '
    </ul>
    '
    ;
    }

    displayMenu(0); // call function for base level

    var_dump($trace);

    更多信息:

    我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!

    但是,我想我是在另一个网站上找到的,这里:

    http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/

    434511

    我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。

    我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。

  • 我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)

    使用参数 "0" 调用函数应该会给你完整的菜单树。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    $trace = array();

    function displayMenu($parent_page_id) {
      $sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
      $result = mysql_query($sql);
      if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
         $trace[] ="Page_id $parent_page_id has no children";
         return true; // exit function
      } // else, continue to rest of function
      echo '
    <ul>
    '
    ;
      while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
         $trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
         echo '
    <li>
    '
    . $row['menu_title'] . ''; // no closing
    </li>
     yet
         displayMenu($row['page_id']); // this is the recursive part
         echo '
    </li>
    '
    ; // close the
    <li>
     from before the recursion
      }
      echo '
    </ul>
    '
    ;
    }

    displayMenu(0); // call function for base level

    var_dump($trace);

    更多信息:

    我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!

    但是,我想我是在另一个网站上找到的,这里:

    http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/

    434511

    我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。

    我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。

  • 我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)

    使用参数 "0" 调用函数应该会给你完整的菜单树。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    $trace = array();

    function displayMenu($parent_page_id) {
      $sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
      $result = mysql_query($sql);
      if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
         $trace[] ="Page_id $parent_page_id has no children";
         return true; // exit function
      } // else, continue to rest of function
      echo '
    <ul>
    '
    ;
      while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
         $trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
         echo '
    <li>
    '
    . $row['menu_title'] . ''; // no closing
    </li>
     yet
         displayMenu($row['page_id']); // this is the recursive part
         echo '
    </li>
    '
    ; // close the
    <li>
     from before the recursion
      }
      echo '
    </ul>
    '
    ;
    }

    displayMenu(0); // call function for base level

    var_dump($trace);

    更多信息:

    我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!

    但是,我想我是在另一个网站上找到的,这里:

    http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/

    434511

    我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。

    我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。


我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。

我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。

  • 看起来我们对 Hillyer 链接达成了共识。
  • 确实 :) 不久前我读过另一篇文章,但我现在很难找到它。
  • 我的书签中有上面的一个,但出于某种原因,他们从 mysql.com 中删除了它。幸运的是,我可以通过谷歌搜索保存在我的谷歌书签中的标题找到它。


我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)

使用参数 "0" 调用函数应该会给你完整的菜单树。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
$trace = array();

function displayMenu($parent_page_id) {
  $sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
  $result = mysql_query($sql);
  if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
     $trace[] ="Page_id $parent_page_id has no children";
     return true; // exit function
  } // else, continue to rest of function
  echo '
<ul>
'
;
  while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
     $trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
     echo '
<li>
'
. $row['menu_title'] . ''; // no closing
</li>
 yet
     displayMenu($row['page_id']); // this is the recursive part
     echo '
</li>
'
; // close the
<li>
 from before the recursion
  }
  echo '
</ul>
'
;
}

displayMenu(0); // call function for base level

var_dump($trace);

更多信息:

我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!

但是,我想我是在另一个网站上找到的,这里:

http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/

  • 巴特尔我正在使用 mysql_query
  • 巴特尔,如果我有任何疑问,我会尽力回复您。谢谢
  • 行。我更改了代码以使用 mysql 函数并输入了实际的 mysql 查询,除了我使用 parent_page_id 而不是 parent_page 因为这对其他人来说更清楚。
  • 是的,好的,巴特尔。试试看
  • 嗨 Buttle,我已经发布了我在问题中写的查询。它没有显示任何输出。我只能在查看源代码中看到 html 标签,但在标签内看不到文本。我写的是否正确。如果有更改,请告诉我
  • 啊,Vishal,你应该发现我的错误。我有 $result['url']$result['menu_tile']。现在修好了。 $row 是变量,而不是 $result。在我意识到错误是什么之前,我还添加了 $trace 变量来检查事情。
  • 很高兴它奏效了。嘿,谢谢你的复选标记!如果你不介意也给我一个赞成票,我也不介意!
  • 我试过巴特尔。但这不会允许我,因为我没有足够的声誉。对不起
  • 你是个天才。我想知道我成为这样的编码员需要多长时间 :)
  • 哈哈谢谢夸奖。我想如果你每天花几个小时,那么你可能也需要 1-2 年才能成为天才。

有关关于 php:在创建动态菜单时需要帮助的更多相关文章

  1. ruby - 如何在 Ruby 中顺序创建 PI - 2

    出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits

  2. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  3. ruby - 我需要将 Bundler 本身添加到 Gemfile 中吗? - 2

    当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/

  4. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  5. ruby-on-rails - 无法使用 Rails 3.2 创建插件? - 2

    我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby​​1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在

  6. ruby - 如何使用 RSpec::Core::RakeTask 创建 RSpec Rake 任务? - 2

    如何使用RSpec::Core::RakeTask初始化RSpecRake任务?require'rspec/core/rake_task'RSpec::Core::RakeTask.newdo|t|#whatdoIputinhere?endInitialize函数记录在http://rubydoc.info/github/rspec/rspec-core/RSpec/Core/RakeTask#initialize-instance_method没有很好的记录;它只是说:-(RakeTask)initialize(*args,&task_block)AnewinstanceofRake

  7. ruby - rspec 需要 .rspec 文件中的 spec_helper - 2

    我注意到像bundler这样的项目在每个specfile中执行requirespec_helper我还注意到rspec使用选项--require,它允许您在引导rspec时要求一个文件。您还可以将其添加到.rspec文件中,因此只要您运行不带参数的rspec就会添加它。使用上述方法有什么缺点可以解释为什么像bundler这样的项目选择在每个规范文件中都需要spec_helper吗? 最佳答案 我不在Bundler上工作,所以我不能直接谈论他们的做法。并非所有项目都checkin.rspec文件。原因是这个文件,通常按照当前的惯例,只

  8. ruby - 如何在 Lion 上安装 Xcode 4.6,需要用 RVM 升级 ruby - 2

    我实际上是在尝试使用RVM在我的OSX10.7.5上更新ruby,并在输入以下命令后:rvminstallruby我得到了以下回复:Searchingforbinaryrubies,thismighttakesometime.Checkingrequirementsforosx.Installingrequirementsforosx.Updatingsystem.......Errorrunning'requirements_osx_brew_update_systemruby-2.0.0-p247',pleaseread/Users/username/.rvm/log/138121

  9. ruby - 为什么 SecureRandom.uuid 创建一个唯一的字符串? - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?

  10. ruby - 有人可以帮助解释类创建的 post_initialize 回调吗 (Sandi Metz) - 2

    我正在阅读SandiMetz的POODR,并且遇到了一个我不太了解的编码原则。这是代码:classBicycleattr_reader:size,:chain,:tire_sizedefinitialize(args={})@size=args[:size]||1@chain=args[:chain]||2@tire_size=args[:tire_size]||3post_initialize(args)endendclassMountainBike此代码将为其各自的属性输出1,2,3,4,5。我不明白的是查找方法。当一辆山地自行车被实例化时,因为它没有自己的initialize方法

随机推荐