- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有以下数据库和 php。我正在尝试制作一个无序列表的类别菜单。原来的 php 是自己工作的。我正在尝试在 codeigniter 中将其转换为 MVC,以下是我到目前为止所得到的但无法正常工作的内容。如果有人能指出我做错了什么,我将不胜感激。
数据库
CREATE TABLE IF NOT EXISTS `categories` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
`shortdesc` varchar(255) NOT NULL,
`longdesc` text NOT NULL,
`status` enum('active','inactive') NOT NULL,
`parentid` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=10 DEFAULT CHARSET=latin1 AUTO_INCREMENT=10 ;
--
-- Dumping data for table `categories`
--
INSERT INTO `categories` (`id`, `name`, `shortdesc`, `longdesc`, `status`, `parentid`) VALUES (1, 'shoes', 'Shoes for boys and girls.', '', 'active', 7);
INSERT INTO `categories` (`id`, `name`, `shortdesc`, `longdesc`, `status`, `parentid`) VALUES (2, 'shirts', 'Shirts and blouses!', '', 'active', 7);
...
...
menu.php(原始 php 和工作)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="content-type" content="text/html; charset=iso-8859-1" />
<title>View Tasks</title>
</head>
<body>
<h3>Menu</h3>
<?php
function make_list ($parent) {
global $data;
echo '<ul>';
foreach ($parent as $task_id => $todo) {
echo "<li>$todo";
if (isset($data[$task_id])) {
make_list($data[$task_id]);
}
echo '</li>';
}
echo '</ul>';
}
$dbc = @mysqli_connect ('localhost', 'root1', 'root', 'ci_day6') OR die ('<p>Could not connect to the database!</p></body></html>');
$q = 'SELECT id, parentid, name FROM categories ORDER BY parentid ASC';
$r = mysqli_query($dbc, $q);
$data = array();
while (list($id, $parentid, $name) = mysqli_fetch_array($r, MYSQLI_NUM)) {
$data[$parentid][$id] = $name;
}
make_list($data[0]);
?>
</body>
</html>
此 php 输出以下 html
Menu
* clothes
o shoes
o shirts
o pants
o dresses
* fun
o toys
o games
我的 MVC 到目前为止还没有工作。
cat_menu_model.php(模型)
<?php
class Cat_menu_model extends Model
{
function Cat_menu_model()
{
parent::Model();
}
function get_categories_nav()
{
$data = array();
$this->db->select('id,name,parentid');
$this->db->where('status', 'active');
$this->db->orderby('parentid','asc');
$this->db->orderby('name','asc');
$Q = $this->db->get('categories');
if ($Q -> num_rows() > 0){
foreach ($Q -> result_array() as $row){
$data[$row['parentid']][$row['id']] = $row['name'];
}
}
$Q->free_result();
return $data;
}
}
cat_menu.php( Controller )
<?php
class Cat_menu extends Controller
{
function Cat_menu()
{
parent::Controller();
}
function make_menu($parent)
{
$this->load->model('cat_menu_model');
$data['navlist'] = $this->cat_menu_model->get_categories_nav();
$this -> load ->view('menu');
}
}
菜单.php( View )
<?php
if (count($navlist))
{
$this->make_menu($data[0]);
echo '<ol>';
foreach ($parent as $id => $catname) {
echo "<li>$catname";
if (isset($data[$id])) {
make_menu($data[$id]);
}
echo '</li>';
}
echo '</ol>';
}
?>
它显示错误信息。
A PHP Error was encountered
Severity: Warning
Message: Missing argument 1 for Cat_menu::make_menu()
Filename: controllers/cat_menu.php
Line Number: 10
最佳答案
鉴于上面的 PHP 错误消息,它表示您已经告诉方法 Cat_menu::make_menu() 接受一个参数。在这种情况下,Cat_menu Controller 中的函数 make_menu($parent)。
如果此函数不需要任何输入——看起来不像使用 $parent——那么只需从 make_menu 中删除 $parent 参数。
或者,如果您希望函数不接受任何参数,则设置一个默认值。见下文:
cat_menu.php( Controller )
<?php
class Cat_menu extends Controller
{
function Cat_menu()
{
parent::Controller();
}
function make_menu($parent = FALSE) //Is this $parent argument needed?
{
$this->load->model('cat_menu_model');
$data['navlist'] = $this->cat_menu_model->get_categories_nav();
//If you want to parse data to a view you need to state it
$this->load->view('menu', $data);
}
}
假设您的其余代码是正确的,现在应该可以工作了。请参阅CodeIgniter User Guide供以后引用。特别是 views documentation关于解析值。
OP* 已在下面的评论中做出回应,这是我的回应。
**OP = 原始海报*
在 View 中运行 print_r($navlist) 时。 OP 获得以下输出:
Array (
[0] => Array (
[7] => clothes
[8] => fun
)
[7] => Array (
[3] => pants
[2] => shirts
[1] => shoes
)
[8] => Array (
[6] => games
[5] => toys
)
)
但是,值得注意的是,OP 的 CI 模型 ActiveRecord 查询与原始的——非 MVC——查询有很大不同:
SELECT
id,
parentid,
name
FROM
categories
ORDER BY
parentid ASC
对比
$this->db->select('id,name,parentid');
$this->db->where('status', 'active');
$this->db->orderby('parentid','asc');
$this->db->orderby('name','asc');
$Q = $this->db->get('categories');
CI 模型查询与最初的原始 SQL 不同。当转换为 SQL 时,它将产生以下结果:
SELECT
id,
name,
parentid
FROM
categories
WHERE
status = 'active'
ORDER BY
parentid ASC,
name ASC
但是,这似乎是带回的正确数据,所以我将继续。
OP 希望数组的格式像层次结构一样。为了将来引用,请参阅:PHP/MySQL - building a nav menu hierarchy .最简单的方法是遵循 OP 的原始(非 MVC)功能并将其添加为模型功能。此模型函数将创建一个嵌套数组,而不是直接的 html 输出——这样做的原因是将应用程序逻辑与输出分开。
您可以将以下内容作为函数添加到您的模型中。最初取自 Nested sets, php array and transformation但由于 OP 出现错误而重写:
function to_hierarchy($collection = NULL)
{
if (is_null($collection)) return false;
$tree = array();
foreach($collection[0] as $key => $value)
{
$tree[$value] = array();
foreach($collection[$key] as $item)
{
array_push($tree[$value], $item);
}
}
return $tree;
}
现在我们可以将 Controller 更新为以下内容:
cat_menu.php( Controller )
<?php
class Cat_menu extends Controller
{
function Cat_menu()
{
parent::Controller();
}
function make_menu($parent = FALSE) //Is this $parent argument needed?
{
$this->load->model('cat_menu_model');
$get_nav_list = $this->cat_menu_model->get_categories_nav();
$format_nav_list = $this->cat_menu_model->to_hierarchy($get_nav_list);
//Load the HTML helper for ul/ol conversion
$this->load->helper('html');
$data['navlist'] = $format_nav_list;
//If you want to parse data to a view you need to state it
$this->load->view('menu', $data);
}
}
现在我们可以更新我们的 View 如下:
menu.php( View )
<?php
echo ul($navlist);
?>
免责声明: 以上均未使用 PHP 进行测试,因为我目前无法从这台计算机访问解释器。请确保检查任何语法。
关于php - 如何从 native php 转换为 codeigniter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1550105/
在这种情况下,我们在应用程序中同时使用react-native-gesture-handler Touchable和react-native Touchable。 (通过Touchables,我的意思
我有一个 MainFooter包含页脚和迷你播放器的组件,单击时动画显示为全 View 。我有一个问题,每当我们点击一个页脚选项卡时,播放器最大化然后卡在那里,没有响应。 此外,播放器内部的向下箭
我在 native react 之上使用 native 基础组件,我想知道如何在 UI 中使卡片呈圆形而不是矩形。有圆形的 Prop 吗? 最佳答案 好吧,实际上没有人能回答这个问题,但幸运的是我在
我在 native react 之上使用 native 基础组件,我想知道如何在 UI 中使卡片呈圆形而不是矩形。有圆形的 Prop 吗? 最佳答案 好吧,实际上没有人能回答这个问题,但幸运的是我在
我是 react-native 的新手,所以我认为“HTML”而不是“native”可能有点太多了,所以我的问题看起来很愚蠢。 我使用 react-native-router-flux 进行路由,并使
当我使用这个例子在我的应用程序上实现 Image-slider 时,我遇到了这个错误。 import React,{Component} from 'react' import {View,T
我正在为我们的产品使用“Native Base”组件,并且效果很好, 但我有一点被卡住了,它是关于将 Items 放入 Nativebase Picker 的问题。我的代码是这样的 渲染方法代码 -
正如文档中所建议的,我将一些长的数据获取代码移动到 native 模块中以释放 JS 线程,但我观察到这仍然阻塞了 UI。为什么会这样,我能做些什么来避免这种情况? 从 JS 调用 native 模块
我正在使用一个名为 react-native-svg 的框架在 React Native View 中绘制 SVG 元素。 我的目标是,当我点击 View 时(我在全局 View 上使用 PanRes
在 IOS 中发现错误 Native Module cannot be null 我不使用 react-native-push-notification 最佳答案 这通常发生在您未能将第三个库链接到您
当应用程序关闭时,我可以获得由 Linking.getInitialURL() 点击的深层链接网址。 .当应用程序处于后台状态时,则不会安装任何内容。所以,我什至无法通过 Linking.addEve
1) 说原生库是什么意思?什么样的图书馆?那些将用作 gradle 依赖项? 2)如何链接这些?我在使用 link 或 rnpm 时遇到了麻烦。 最佳答案 链接 native 库意味着您要将已经实现的
我需要帮助来构建我的 react 原生项目。我尝试过react-native run-android,但出现以下错误: react-native : The term 'react-native' i
我需要帮助来构建我的 react 原生项目。我尝试过react-native run-android,但出现以下错误: react-native : The term 'react-native' i
我是 React-Native 的新手,到目前为止我很喜欢它。我正在尝试创建一个屏幕(用于跨平台应用程序),右上角有一个菜单图标,单击时,我想打开一个菜单,希望使用 react-native-menu
RN doco 和其他示例展示了如何从 native iOS View Controller 启动 React-Native View ,但反之则不然。谁能解释一下我该怎么做? 最佳答案 我能够弄清楚
对于 react-native - WebStorm 用户: 我正在使用 Jet Brains IDE WebStorm 开始一个带有 React Native 的项目。 在项目 => node_mo
在升级过去的 react-native 0.60 之后......我被警告我应该取消链接所有手动链接的第 3 方库(因为 RN 现在通过自动链接处理它)。 但是,当我运行 react-native u
你可以使用像 https://github.com/tolu360/react-native-google-places 这样的库吗?在世博项目中?我假设任何 npm 库都可以添加,但是像这个 goo
我主要喜欢 React Native。自 0.22 以来一直在使用它。目前为 0.35。 但是为什么链接原生库就像抽奖一样呢?我很少在第一次拍摄时让它发挥作用,而破裂的东西通常是完全不同的东西。 每个
我是一名优秀的程序员,十分优秀!