Skip to main content

Ajax Form Submission AngularJS

Ajax Form Submission AngularJS

AngularJS is an MVC JavaScript framework which elegantly separates controller, business and model logic in your application.

HTML page

<!DOCTYPE html>
<html>
<head>
<script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2.26/angular.min.js"></script>
</head>
<body ng-app="AddUser">
<form ng-controller="AppCtrl" name="add_user">
            <div class="modal-header">
                <h3 class="modal-title">Add User Form</h3>
            </div>
            <div class="modal-body">
                <input type="text" class="form-control" name="user_email" ng-model="user_name" placeholder="Enter Name">
                    <br />
                <input type="text" class="form-control" name="user_name" ng-model="user_email" placeholder="Enter Email">
            </div>
            <div class="modal-footer">
                <input type="button" class="btn btn-success" name="add_user" value="Invite" ng-click="save_user()">
            </div>
    </form>
</body>
<script src="app.js"></script>

</html>

External JS file app.js

var app = angular.module('AddUser', []);

app.controller('AppCtrl', function($scope, $http){
$scope.save_user = function() {
$http.post('db.php',
{
'user_name'  : $scope.user_name,
'user_email' : $scope.user_email
}
)
.success(function (data) {
console.log("The user has been added successfully");
})
.error(function(data) {
console.log("Failed to add the user to DB ");
});
}

});

db.php file for handling database connection

$data = json_decode(file_get_contents("php://input"));
$servername = "localhost";
$username = "root";
$password = "";
$db = "sidpractice";
$conn = mysql_connect($servername, $username, $password) or die(mysql_error()." Error1 ");
mysql_select_db($db,$conn);
        $data = json_decode(file_get_contents("php://input"));
        $user_name = $data->user_name;  
        $user_email = $data->user_email;
        $qry = 'INSERT INTO filler(user_name, user_email) VALUES             ("'.$user_name.'","'.$user_email.'")';
    $qry_res = mysql_query($qry,$conn) or die(mysql_error()." Error2 ");
    if ($qry_res) {
        $arr = array('msg' => "Success");
        $jsn = json_encode($arr);
    }
    else {
        $arr = array('msg' => "Error");
        $jsn = json_encode($arr);

    }

Notes:

  • The ng-app property defines an AngularJS application.
  • The ng-model property binds the value of HTML controls (input, select, textarea) to application data.
  • We define the scope of our controller using the ng-controller directive.It will be in charge of processing the contents of this piece of HTML.
  • The ng-click event call the save_user function inside app.js controller.
If you want submit form like serialize you have to change little in code
Change ng-model name as
 <input type="text" class="form-control" name="user_email" ng-model="formData.user_name" placeholder="Enter Name">
                    <br />
                <input type="text" class="form-control" name="user_name" ng-model="formData.user_email" placeholder="Enter Email">

Change in controller by
$scope.formData = {};
$scope.save_user = function() {
console.log(this.formData);
    $http.post('db.php?action=add_user', 
        {
            'data'  : this.formData/* , 
            'user_email' : $scope.user_email */
        }
    )}

Comments

Popular posts from this blog

Generate XML file in Cakephp

Steps to Generate XML file using CakePHP: Step-1 Enable to parse xml extension in config route.php file.     Router::parseExtensions('xml'); Step-2 Add Request Handler Component to the Controller    var $components = array(‘RequestHandler’); Step-3 Add controller Action For XML Generation in Post Controller     function generateXMLFile()     {         if ($this->RequestHandler->isXml()) { // check request type             $this->layout = 'empty'; // create an empty layout in app/views/layouts/empty.ctp              }        }  Add header code in empty layout <?php header('Content-type: text/xml');?> <?php echo $this->Xml->header(); ?> <?php echo $content_for_layout; ?> Step-4 Set up View To generate XML Create xml folder inside Posts vi...

How To Create Shortcodes In WordPress

We can create own shortcode by using its predified hooks add_shortcode( 'hello-world', 'techsudhir_hello_world_shortcode' ); 1. Write the Shortcode Function Write a function with a unique name, which will execute the code you’d like the shortcode to trigger: function techsudhir_hello_world_shortcode() {    return 'Hello world!'; } Example: [hello-world] If we were to use this function normally, it would return Hello world! as a string 2. Shortcode function with parameters function techsudhir_hello_world_shortcode( $atts ) {    $a = shortcode_atts( array(       'name' => 'world'    ), $atts );    return 'Hello ' . $a['name'] . !'; } Example: [hello-world name="Sudhir"] You can also call shortcode function in PHP using do_shortcode function Example: do_shortcode('[hello-world]');

How to replace plain URLs with links

Here we will explain how to replace Urls with links from string Using PHP $string ='Rajiv Uttamchandani is an astrophysicist, human rights activist, and entrepreneur. Academy, a nonprofit organization dedicated to providing a robust technology-centered education program for refugee and displaced youth around the world.  CNN Interview - https://www.youtube.com/watch?v=EtTwGke6Jtg   CNN Interview - https://www.youtube.com/watch?v=g7pRTAppsCc&feature=youtu.be'; $string = preg_replace('@(https?://([-\w\.]+)+(:\d+)?(/([\w/_\.%-=#]*(\?\S+)?)?)?)@', '<a href="$1">$1</a>', $string); Using Javascript <script> function linkify(inputText) {     var replacedText, replacePattern1, replacePattern2, replacePattern3;     //URLs starting with http://, https://, or ftp://     replacePattern1 = /(\b(https?|ftp):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/gim;     replacedText = inputT...