如何在codeigniter中将数据从视图发送到控制器

时间:2016-03-10 12:53:15

标签: javascript php database codeigniter

我是代码点火器的新手。在我的视图中,我添加了此代码,以便在我的网站中启用Google登录。

<html lang="en">
<head>
<meta name="google-signin-scope" content="profile email">
<meta name="google-signin-client_id" content="720765566138-5c6jreo4r7ma6cm0hdblj5cmjtdiruk4.apps.googleusercontent.com">
<script src="https://apis.google.com/js/platform.js" async defer>     </script>
</head>
<body>
<div class="g-signin2" data-onsuccess="onSignIn" data-onfailure="onFailure" data-theme="dark"></div>
<script>
function onFailure(msg){ console.log(msg); }
function onSignIn(googleUser) {
    console.log("onSignIn");
    var profile = googleUser.getBasicProfile();
    var user_name = profile.getName();
    var id = googleUser.getAuthResponse().id;
};
</script>
</body>
</html>

如何将变量user_name和id发送到Controller,以便我可以调用Model将值插入数据库。

3 个答案:

答案 0 :(得分:2)

你必须做出控制器的动作,在这里你必须传递这样的变量:

function test{
    $user_name = "XYZ";
    $this->load->view('view_name', $user_name);
    }

如果您想传递多个变量,请使用以下内容:

function test{
        $user_name = "XYZ";
        $data = 123;
        $this->load->view('view_name', array("user_name"=>$user_name,"data"=>$data));
    }
May this will help you :)

答案 1 :(得分:2)

如果您的方法为Form

,则Ajax或使用post正常提交
$this->input->post();

此方法默认包含其他所有数据get方法

$this->input->get();

让你的form如下

 <form action="baseurl/controller_name/method">
 add hidden field of user_id then sumbmit 
 </form>

在您的控制器中

  function YOUR_METHOD()
  {
      print_r($this->input->get())//By default get method
  } 

答案 2 :(得分:2)

您可以在获得信息后使用ajax发布信息(使用下面的jquery):

<script>
    function onSignIn(googleUser)
   {
       var profile = googleUser.getBasicProfile();
       var user_name = profile.getName();
       var id = googleUser.getAuthResponse().id;
       $.ajax({
               'url': 'the/path/to/controller',
               'type': 'POST',
               'data':{'user_name': user_name, 'id':id},
               'success': function(){}, //up to you
               'error': function() // up to you
             })
    };
</script>