2

如何使用 get 或 post 方法将用户输入的数据从视图传递到 codeigniter Php 中的控制器?我目前是 codeigniter 的新手..谢谢!

AddProduct.php(我的观点)

<body>
    <form method="POST" action="SaveProductController"></br></br></br>
        <table border='1' align='center'>
            <tr>
                <td>ID: </td><td><input type="text" name="id" 
                                        value="<?php echo $GetProductId->id + 1; ?>" readonly="readonly"></td>
            </tr>
            <tr>
                <td>Description: </td><td><input type="text" name="description"></td>
            </tr>
            <tr>
                <td></td><td><input type="submit" name="addProduct" value="Add Product"><td>
            </tr>
        </table>
    </form>
</body>

SaveProductController .php(我的控制器)

class SaveProductController extends CI_Controller{

function index($description){
    $this->load->model('ProductDao');
    $data['id'] = $this->id;
    $data['description'] = $this->description;
    print_r($data);
    //$this->ProductDao->saveProduct();
}

}

ProductDao.php

 function saveProduct() {
    $data = array(
    'id' => $this->input->xss_clean($this->input->post('id')),
    'description' => $this->input->xss_clean($this->input->post('description')),
    'price' => $this->input->xss_clean($this->input->post('price')),
    'size' => $this->input->xss_clean($this->input->post('size')),
    'aisle' => $this->input->xss_clean($this->input->post('aisle')),
    );

    $query = $this->db->insert('mytable', $data);
}
4

2 回答 2

5
<body>
    <form method="POST" action="<?php echo $this->base_url();?>/controllername/methodname"></br></br></br>
        <table border='1' align='center'>
            <tr>
                <td>ID: </td><td><input type="text" name="id" 
                                        value="<?php echo $GetProductId->id + 1; ?>" readonly="readonly"></td>
            </tr>
            <tr>
                <td>Description: </td><td><input type="text" name="description"></td>
            </tr>
            <tr>
                <td></td><td><input type="submit" name="addProduct" value="Add Product"><td>
            </tr>
        </table>
    </form>
</body>

观察动作变化

并在您的控制器指定的方法中获取如下所示的值

$id=$this->input->post('id')
$idescription=$this->input->post('description')

然后将这些发送到模型并做任何你想做的事

加载 url 帮助程序库以使其$this->baseurl()使用其他明智的硬代码工作localhost/path...

于 2012-12-27T07:52:46.970 回答
4

我创建了名为:Test_controller 的控制器和名为:manage_test_controller 的视图,使用下面的代码,您可以从视图文件获取数据到控制器。

测试控制器.php

 class Test_controller extends CI_Controller {

        var $controller = "user";
        var $formValues = array();
    function manage_user() {               

                $this->formValues['formAction'] = SITEURL . '/' . 
                $this->controller . '/manage_' . $this->controller;

                if (isset($_POST['displayName']))
                    $this->formValues['displayName'] = $_POST['displayName']; 
                else
                    $this->formValues['displayName'] = "";
                if (isset($_POST['userEmail']))
                    $this->formValues['userEmail'] = $_POST['userEmail']; else
                    $this->formValues['userEmail'] = "";                   

            $this->load->view('header');
            $this->load->view($this->controller . '/manage_' . 
            $this->controller, $this->formValues);
            $this->load->view('footer');
        }
    }

Manage_test_controller.php

<?php echo form_open_multipart($formAction); ?>
<table>
    <tr>
            <td><?php echo form_label('Display Name'); ?><em>*</em></td>
            <td><?php echo form_input('displayName',$displayName); ?></td>
        </tr>
    <tr>
            <td><?php echo form_label('Email'); ?><em>*</em></td>
            <td><?php echo form_input('userEmail',$userEmail); ?></td>
        </tr>
</table>
<?php echo form_close(); ?>

希望这段代码对您有所帮助.... :)

于 2012-12-27T13:24:44.570 回答