zoukankan      html  css  js  c++  java
  • AngularJS CRUD Example with PHP, MySQL and Material Design

    https://www.codeofaninja.com/2015/12/angularjs-crud-example-php.html


    Previously, we have learned how to program CRUD with PHP, AJAX and OOP. Today, we will learn how to do CRUD with AngularJS, PHP and MySQL.

    Welcome to the fifth part of the series. I’m happy to see you here, I love to see a person like you who has a great desire for learning!

    I highly recommend studying the previous tutorials first before proceeding here. But if you think you can take this one, then go on.

    This tutorial will focus on creating, reading, updating, deleting and searching database records. We will do it using a Google’s AngularJS, PHP and MySQL.

    As for the user interface, instead of Bootstrap, we will use Materialize CSS – a modern responsive front-end framework based also on Google’s Material Design.


    jQuery will also help us a little bit with modals. PDO and OOP will help us with the PHP part.

    This will lead to other useful features like pagination, CSV downloads and more.

    Contents of this post will include:

    1.0 AngularJS CRUD Example PHP – Output

    2.0 File Structure

    3.0 Database table and connection
    3.1 Create the database table
    3.2 Dump sample data on the table
    3.3 PHP script to connect to database

    4.0 Put assets inside certain directories
    4.1 Put AngularJS and jQuery libraries in “libs/js/” folder
    4.2 Put Materialize CSS framework in “libs/css/” folder

    5.0 Create “objects” folder with product.php object file
    5.1 Basic code for the “product” class

    6.0 Make use of your HTML coding skills
    6.1 Create basic HTML code structure for index.php
    6.2 Add custom CSS
    6.3 Put the most important DIV tag

    7.0 Create or insert data using AngularJS in PHP
    7.1 HTML button to show the “create product HTML form”
    7.2 HTML code of “create product form”
    7.3 AngularJS Basic Code
    7.4 AngularJS “showCreateForm” function to show “create product form”
    7.5 AngularJS “clearForm” function to remove any form values that exists
    7.6 AngularJS “createProduct” function
    7.7 PHP code to create a record
    7.8 Object code to create a record
    7.9 Output should look like this

    8.0 Read data using AngularJS in PHP
    8.1 Display list of data in table
    8.2 AngularJS code to read records
    8.3 PHP script to read records
    8.4 Object code to read records
    8.5 Output should look like this

    9.0 Update data using AngularJS in PHP
    9.1 AngularJS code to read details of record to be edited
    9.2 PHP script to read details of a record
    9.3 Object code to read single record
    9.4 AngularJS code to update a record
    9.5 PHP script to update a record
    9.6 Object code to update a record
    9.7 Output should look like this

    10.0 Delete data using AngularJS in PHP
    10.1 AngularJS code to delete a record
    10.2 PHP script to delete a record
    10.3 Object code to delete a record
    10.4 Output should look like this

    11.0 What People Say About This Code?

    12.0 Download Source Code

    13.0 Some Notes

    1.0 AngularJS CRUD Example PHP – Output

    1.1 LEVEL 1 Source Code Output

    To see the LEVEL 1 full list of features, go to section 12.1 below.

    1.2 LEVEL 2 Source Code Output

    To see the LEVEL 2 full list of features, go to section 12.2 below.

    1.3 LEVEL 3 Source Code Output

    To see the LEVEL 3 full list of features, go to section 12.3 below.

    2.0 File Structure

    Knowing the file structure will give us an overview of what PHP files do we need to create and where the assets should be placed.

    0-angular-js-php-crud-file-structure

    3.0 Database structure and connection

    We have to create a database, then a table with the following table structure, and a PHP file that we will use for database connection.

    3.1 Create the database table

    Run the following SQL code on your PhpMyAdmin. This is to create our database table. By the way, the database name we used in this tutorial was named “phpajaxcrudlevel1”.

    --
    -- Table structure for table `products`
    --
    
    CREATE TABLE IF NOT EXISTS `products` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(512) NOT NULL,
      `description` text NOT NULL,
      `price` int(11) NOT NULL,
      `created` datetime NOT NULL,
      `modified` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
      PRIMARY KEY (`id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=64 ;
    

    3.2 Dump sample data on the table

    Run the following SQL code on your PhpMyAdmin again, this will pre-insert sample data or record on our “products” database table.

    --
    -- Dumping data for table `products`
    --
    
    INSERT INTO `products` (`id`, `name`, `description`, `price`, `created`, `modified`) VALUES
    (1, 'LG Optimus 4X HD P880 Black', 'Display - True HD-IPS LCD - 720 x 1280 pixels, 4.7 inches. Internal Memory - 16 GB storage (12 GB user available), 1 GB RAM. Camera - 8 MP, 3264x2448 pixels, autofocus, LED flash', 309, '2014-06-01 01:12:26', '2014-05-31 17:12:26'),
    (2, 'Motorola Google Nexus 6, Midnight Blue 32GB', 'The stunning 6 inch Quad HD display is great for movies, videos, gaming, e-books, and surfing the Web, and the Nexus 6 provides exceptional battery life.', 400, '2014-06-01 01:12:26', '2014-05-31 17:12:26'),
    (3, 'Samsung Galaxy S4 i9500 16GB', 'Make your life richer, simpler, and more fun. As a real life companion, the new Samsung GALAXY S4 helps bring us closer and captures those fun moments when we are together. Each feature was designed to simplify our daily lives. Furthermore, it cares enough to monitor our health and well being.', 600, '2014-06-01 01:12:26', '2014-05-31 17:12:26'),
    (6, 'Bench Men''s Bench Spokes Slim T-Shirt', 'Make their heads spin by rollin'' through with swag to spare. Cotton-poly heather blend provides for a soft, comfortable wear. Screen printed Bench graphics on front. Slim fitting for modern appeal. Contrast topstitching along shoulders. Ribbed crew neck. Short sleeves', 14, '2014-06-01 01:12:26', '2014-05-31 02:12:21'),
    (7, 'HP ZBook 17 Mobile Business Workstation', 'Feel the power! Take performance to a new level with the HP ZBook 17 with Intel''s quad core CPU and 4GB GDDR5 Nvidia Quadro graphics.  Project a professional image at the office, client meetings, and on the road without sacrificing durability in a stylish chassis.', 5149, '2014-06-01 01:13:45', '2014-05-31 02:13:39'),
    (8, 'Samsung Galaxy Tab 4', 'Ideal for watching HD movies, playing games, browsing the web, or reading, the Samsung Galaxy Tab 4 features a 10.1-inch, 1280x800 resolution screen, so you experience rich graphics, bright colors, and crisp text.', 210, '2014-06-01 01:14:13', '2014-05-31 02:14:08'),
    (9, 'Spalding Men', 'Right from the beginning, it was all about being first, being the best???being what others could only dream of becoming. Founded by Boston Red Stockings pitcher A.G. Spalding in 1876, Spalding has become a leader of innovation and quality in the sporting goods industry.', 49, '2014-06-01 01:18:36', '2014-05-31 02:18:31'),
    (10, 'Sony Smart Watch 3', 'Contextually aware and smart, Android Wear gives you useful information at a glance and responds to your voice, feeding you relevant and specific information as you move.', 194, '2014-06-06 17:10:01', '2014-06-05 18:09:51'),
    (11, 'Huawei SnapTo', 'Support all GSM 4G LTE Networks ( T-Mobile, AT&T, Straight Talk, NET10, etc.). 75% screen-body ratio and a stylish, leather-texture finish battery cover with a slim design make the phone compac', 179, '2014-06-06 17:11:04', '2014-06-05 18:10:54'),
    (12, 'Abercrombie Men''s Lake Arnold Blazer', '100% Gabardine wool imported from Italy. Classic collegiate blazer with heritage A&F crest at left chest pocket. Front pockets with fold-over flaps.', 25, '2014-06-06 17:12:21', '2014-06-05 18:12:11');
    

    As you may have noticed, steps 1 and 2 are both SQL queries. Yes, they can be run at the same time. But I wanted it to be on separate steps to emphasize the SQL queries’ purpose.

    3.3 PHP script to connect to database

    Create a folder named “config” and inside it, create a database.php file with the following code. It answers how to connect to MySQL database with PDO?

    conn = null;
    		
    		try{
    			$this->conn = new PDO("mysql:host=" . $this->host . ";dbname=" . $this->db_name, $this->username, $this->password);
    		}catch(PDOException $exception){
    			echo "Connection error: " . $exception->getMessage();
    		}
    		
    		return $this->conn;
    	}
    }
    ?>
    

    4.0 Put assets inside certain directories

    4.1 Put AngularJS and jQuery libraries in “libs/js/” folder

    Download AngularJS and jQuery libraries and put it in “libs/js/” folder. This will enable us to use AngularJS and jQuery libraries even if we are offline.

    4.2 Put Materialize CSS framework in “libs/css/” folder

    Download Materialize CSS framework and put it in “libs/css/” folder. This will enable us to use Material Design even if we are offline.

    5.0 Create “objects” folder with product.php object file

    The product.php file is located inside the “objects” folder. Put the following basic code for the “product” class.

    conn = $db;
        }
    }
    

    6.0 Make use of your HTML coding skills

    6.1 Create basic HTML code structure for index.php

    Create the index.php file. This is the only page the user has to interact with. Make it ready for AngularJS, Material Design and jQuery by including the necessary library sources.

    
    
    
    
    
    
    
    	Read Products
    
    
    	
    	
    	
    	
    	
    
    
    
    
    
    
    
    
    
    
    // angular js codes will be here
    
    // jquery codes will be here
    
    

    6.2 Add custom CSS

    Put this code before the end “head” tag. We use some custom CSS to make our user interface look better.

    
    
    .width-30-pct{
    	30%;
    }
    
    .text-align-center{
    	text-align:center;
    }
    
    .margin-bottom-1em{
    	margin-bottom:1em;
    }
    
    

    6.3 Put the most important DIV tag

    Inside this “div” tag is where every main content of the page will be loaded. Add the following code after the opeing “body” tag.

    Products

    7.0 Create or insert data using AngularJS in PHP

    7.1 HTML button to show the “create product HTML form”

    Put the following code under the “h4” tag in section 6.3, it will make a floating red button located at the lower right corner of the page.

    add

    7.2 HTML code of “create product form”

    Put the following code under the code in section 7.1 above. It is a form shown via modal or pop up. We will also use the same HTML form for updating a record later.

    
    

    7.3 AngularJS Basic Code

    Put the following AngularJS code inside the “script” tag of section 6.1 above.

    var app = angular.module('myApp', []);
    app.controller('productsCtrl', function($scope, $http) {
    	// more angular JS codes will be here
    });
    

    7.4 AngularJS “showCreateForm” function to show “create product form”

    Put the following code inside the app.controller curly braces in section 7.3 above.

    $scope.showCreateForm = function(){
    	// clear form
    	$scope.clearForm();
    	
    	// change modal title
    	$('#modal-product-title').text("Create New Product");
    	
    	// hide update product button
    	$('#btn-update-product').hide();
    	
    	// show create product button
    	$('#btn-create-product').show();
    	
    }
    

    7.5 AngularJS “clearForm” function to remove any form values that exists

    Put the following code under the “showCreateForm” function code in section 7.4 above.

    // clear variable / form values
    $scope.clearForm = function(){
    	$scope.id = "";
    	$scope.name = "";
    	$scope.description = "";
    	$scope.price = "";
    }
    

    7.6 AngularJS “createProduct” function

    The following code is triggered when the “Create Product” button on the modal or pop up form was clicked.

    // create new product 
    $scope.createProduct = function(){
    		
    	// fields in key-value pairs
    	$http.post('create_product.php', {
    			'name' : $scope.name, 
    			'description' : $scope.description, 
    			'price' : $scope.price
    		}
    	).success(function (data, status, headers, config) {
    		console.log(data);
    		// tell the user new product was created
    		Materialize.toast(data, 4000);
    		
    		// close modal
    		$('#modal-product-form').closeModal();
    		
    		// clear modal content
    		$scope.clearForm();
    		
    		// refresh the list
    		$scope.getAll();
    	});
    }
    

    7.7 PHP code to create a record

    Create a new file with a name “create_product.php”, it will receive all the data inputted by the user. It will also insert the data to the database with the help of the object code in section 7.8 below. Put the following code inside it.

    getConnection();
    
    // instantiate product object
    include_once 'objects/product.php';
    $product = new Product($db);
    
    // get posted data
    $data = json_decode(file_get_contents("php://input")); 
    
    // set product property values
    $product->name = $data->name;
    $product->price = $data->price;
    $product->description = $data->description;
    $product->created = date('Y-m-d H:i:s');
    	
    // create the product
    if($product->create()){
    	echo "Product was created.";
    }
    
    // if unable to create the product, tell the user
    else{
    	echo "Unable to create product.";
    }
    ?>
    

    7.8 Object code to create a record

    In your objects/product.php, add the following code to create a database record.

    // create product
    function create(){
    	
    	// query to insert record
    	$query = "INSERT INTO 
    				" . $this->table_name . " 
    			SET 
    				name=:name, price=:price, description=:description, created=:created";
    	
    	// prepare query
    	$stmt = $this->conn->prepare($query);
    
    	// posted values
    	$this->name=htmlspecialchars(strip_tags($this->name));
    	$this->price=htmlspecialchars(strip_tags($this->price));
    	$this->description=htmlspecialchars(strip_tags($this->description));
    
    	// bind values
    	$stmt->bindParam(":name", $this->name);
    	$stmt->bindParam(":price", $this->price);
    	$stmt->bindParam(":description", $this->description);
    	$stmt->bindParam(":created", $this->created);
    	
    	// execute query
    	if($stmt->execute()){
    		return true;
    	}else{
    		echo "
    
    ";
    			print_r($stmt->errorInfo());
    		echo "
    "; return false; } }

    7.8 Output should look like this

    1-angular-js-php-crud-create-product

    8.0 Read data using AngularJS in PHP

    8.1 Display list of data in table

    We will put the following code under the “h4” tag of our index.php

      
    
    ID Name Description Price Action
    {{ d.id }} {{ d.name }} {{ d.description }} {{ d.price }} editEdit deleteDelete

    8.2 AngularJS code to read records

    The following code will be inside the AngularJS app.controller curly braces.

    // read products
    $scope.getAll = function(){
    	$http.get("read_products.php").success(function(response){
    		$scope.names = response.records;
    	});
    }
    

    8.3 PHP script to read records

    Create a new file named read_products.php, it will retrieve records from the database. The code will look like the following.

    getConnection();
    
    // initialize object
    $product = new Product($db);
    
    // query products
    $stmt = $product->readAll();
    $num = $stmt->rowCount();
    
    // check if more than 0 record found
    if($num>0){
    	
    	$data="";
    	$x=1;
    	
    	// retrieve our table contents
    	// fetch() is faster than fetchAll()
    	// http://stackoverflow.com/questions/2770630/pdofetchall-vs-pdofetch-in-a-loop
    	while ($row = $stmt->fetch(PDO::FETCH_ASSOC)){
    		// extract row
    		// this will make $row['name'] to
    		// just $name only
    		extract($row);
    		
    		$data .= '{';
    			$data .= '"id":"'  . $id . '",';
    			$data .= '"name":"'   . $name . '",';
    			$data .= '"description":"'   . html_entity_decode($description) . '",';
    			$data .= '"price":"' . $price . '"';
    		$data .= '}'; 
    		
    		$data .= $x<$num ? ',' : ''; 
    		
    		$x++;
    	}
    }
    
    // json format output
    echo '{"records":[' . $data . ']}';
    ?>
    

    8.4 Object code to read records

    Put the following code in our objects/product.php file.

    // read products
    function readAll(){
    
    	// select all query
    	$query = "SELECT 
    				id, name, description, price, created 
    			FROM 
    				" . $this->table_name . " 
    			ORDER BY 
    				id DESC";
    
    	// prepare query statement
    	$stmt = $this->conn->prepare( $query );
    	
    	// execute query
    	$stmt->execute();
    	
    	return $stmt;
    }
    

    8.5 Output should look like this

    Now we can view the product list and try the search feature.

    2-angular-js-php-crud-read-products

    9.0 Update data using AngularJS in PHP

    9.1 AngularJS code to read details of record to be edited

    The following code will help put the details of record to be edited to our HTML form.

    // retrieve record to fill out the form
    $scope.readOne = function(id){
    	
    	// change modal title
    	$('#modal-product-title').text("Edit Product");
    	
    	// show udpate product button
    	$('#btn-update-product').show();
    	
    	// show create product button
    	$('#btn-create-product').hide();
    	
    	// post id of product to be edited
    	$http.post('read_one.php', {
    		'id' : id 
    	})
    	.success(function(data, status, headers, config){
    		
    		// put the values in form
    		$scope.id = data[0]["id"];
    		$scope.name = data[0]["name"];
    		$scope.description = data[0]["description"];
    		$scope.price = data[0]["price"];
    		
    		// show modal
    		$('#modal-product-form').openModal();
    	})
    	.error(function(data, status, headers, config){
    		Materialize.toast('Unable to retrieve record.', 4000);
    	});
    }
    

    9.2 PHP script to read details of a record

    Create a file named read_one.php and put the following code. Section 9.1 above will not work without this.

    getConnection();
    
    // prepare product object
    $product = new Product($db);
    
    // get id of product to be edited
    $data = json_decode(file_get_contents("php://input"));     
    
    // set ID property of product to be edited
    $product->id = $data->id;
    
    // read the details of product to be edited
    $product->readOne();
    
    // create array
    $product_arr[] = array(
    	"id" =>  $product->id,
    	"name" => $product->name,
    	"description" => $product->description,
    	"price" => $product->price
    );
    
    // make it json format
    print_r(json_encode($product_arr));
    ?>
    

    9.3 Object code to read single record

    Put the following code inside our objects/product.php file.

    // used when filling up the update product form
    function readOne(){
    	
    	// query to read single record
    	$query = "SELECT 
    				name, price, description  
    			FROM 
    				" . $this->table_name . " 
    			WHERE 
    				id = ? 
    			LIMIT 
    				0,1";
    
    	// prepare query statement
    	$stmt = $this->conn->prepare( $query );
    	
    	// bind id of product to be updated
    	$stmt->bindParam(1, $this->id);
    	
    	// execute query
    	$stmt->execute();
    
    	// get retrieved row
    	$row = $stmt->fetch(PDO::FETCH_ASSOC);
    	
    	// set values to object properties
    	$this->name = $row['name'];
    	$this->price = $row['price'];
    	$this->description = $row['description'];
    }f
    

    9.4 AngularJS code to update a record

    The following code will be triggered when the “Save Changes” button in the modal was clicked. Put it inside the app.controller curly braces.

    // update product record / save changes
    $scope.updateProduct = function(){
    	$http.post('update_product.php', {
    		'id' : $scope.id,
    		'name' : $scope.name, 
    		'description' : $scope.description, 
    		'price' : $scope.price
    	})
    	.success(function (data, status, headers, config){             
    		// tell the user product record was updated
    		Materialize.toast(data, 4000);
    		
    		// close modal
    		$('#modal-product-form').closeModal();
    		
    		// clear modal content
    		$scope.clearForm();
    		
    		// refresh the product list
    		$scope.getAll();
    	});
    }
    

    9.5 PHP script to update a record

    Create a new file and name it “update_product.php”, it will have the following code. Code in section 9.4 will not work without it.

    getConnection();
    
    // prepare product object
    $product = new Product($db);
    
    // get id of product to be edited
    $data = json_decode(file_get_contents("php://input"));     
    
    // set ID property of product to be edited
    $product->id = $data->id;
    
    // set product property values
    $product->name = $data->name;
    $product->price = $data->price;
    $product->description = $data->description;
    
    // update the product
    if($product->update()){
    	echo "Product was updated.";
    }
    
    // if unable to update the product, tell the user
    else{
    	echo "Unable to update product.";
    }
    ?>
    

    9.6 Object code to update a record

    Add the following code in our objects/product.php file.

    // update the product
    function update(){
    
    	// update query
    	$query = "UPDATE 
    				" . $this->table_name . " 
    			SET 
    				name = :name, 
    				price = :price, 
    				description = :description 
    			WHERE
    				id = :id";
    
    	// prepare query statement
    	$stmt = $this->conn->prepare($query);
    
    	// posted values
    	$this->name=htmlspecialchars(strip_tags($this->name));
    	$this->price=htmlspecialchars(strip_tags($this->price));
    	$this->description=htmlspecialchars(strip_tags($this->description));
    
    	// bind new values
    	$stmt->bindParam(':name', $this->name);
    	$stmt->bindParam(':price', $this->price);
    	$stmt->bindParam(':description', $this->description);
    	$stmt->bindParam(':id', $this->id);
    	
    	// execute the query
    	if($stmt->execute()){
    		return true;
    	}else{
    		return false;
    	}
    }
    

    9.7 Output should look like this

    When you clicked an “Edit” button in the product list, you should see the modal with form data of record to be edited.

    3-angular-js-php-crud-update-product

    10.0 Delete data using AngularJS in PHP

    10.1 AngularJS code to delete a record

    Put the following code inside the app.controller part of our AngularJS code.

    // delete product
    $scope.deleteProduct = function(id){
    	
    	// ask the user if he is sure to delete the record
    	if(confirm("Are you sure?")){
    		// post the id of product to be deleted
    		$http.post('delete_product.php', {
    			'id' : id
    		}).success(function (data, status, headers, config){
    			
    			// tell the user product was deleted
    			Materialize.toast(data, 4000);
    			
    			// refresh the list
    			$scope.getAll();
    		});
    	}
    }
    

    10.2 PHP script to delete a record

    Create a new file, name it “delete_product.php” and put the following code inside it.

    getConnection();
    
    // prepare product object
    $product = new Product($db);
    
    // get product id
    $data = json_decode(file_get_contents("php://input"));     
    
    // set product id to be deleted
    $product->id = $data->id;
    
    // delete the product
    if($product->delete()){
    	echo "Product was deleted.";
    }
    
    // if unable to delete the product
    else{
    	echo "Unable to delete object.";
    }
    ?>
    

    10.3 Object code to delete a record

    Put the following code inside our objects/product.php file.

    // delete the product
    function delete(){
    
    	// delete query
    	$query = "DELETE FROM " . $this->table_name . " WHERE id = ?";
    	
    	// prepare query
    	$stmt = $this->conn->prepare($query);
    	
    	// bind id of record to delete
    	$stmt->bindParam(1, $this->id);
    
    	// execute query
    	if($stmt->execute()){
    		return true;
    	}else{
    		return false;
    	}
    }
    

    10.4 Output should look like this

    When a delete button was clicked, it will show a confirmation pop up. When the user clicked “Ok”, a toast message will appear confirming the deletion of a record.

    4-angular-js-php-crud-delete-product

    11.0 What People Say About This Code?

    We tried to share this post online and the following are what people think.

    testimonial-1-angularjs-crud-example-php

    testimonial-2-angularjs-crud-example-php

    12.0 Source Code Download

    You can get the source code by following the whole, well detailed tutorial above. But isn’t it more convenient if you can just download the complete source code we used, and play around it?

    There’s a small fee in getting the complete source code, it is small compared to the:

    ? Value or skill upgrade it can bring you, or YES
    ? Income you can get from your website project or business. YES
    ? Precious time you save. YES

    For a limited time, I will give you the source code for a low price. DOWNLOAD THE SOURCE CODE LEVEL you desire by clicking its the BUY button below.

    <script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>
    阅读(23) | 评论(0) | 转发(0) |
    给主人留下些什么吧!~~
    评论热议
  • 相关阅读:
    Mysql一分钟定位 Next-Key Lock,你需要几分钟
    golang 服务大量 CLOSE_WAIT 故障排查
    Mysql大并发热点行更新的两个骚操作
    golang 服务诡异499、504网络故障排查
    golang 服务平滑重启小结
    vim 列编辑模式
    特邀全球互联网技术大会(麒麟会GITC)分享 —大型团购系统架构设计
    ElasticSearch 评分排序
    zookeeper 实现分布式锁安全用法
    诡异的druid链接池链接断开故障经验总结
  • 原文地址:https://www.cnblogs.com/ztguang/p/12649624.html
Copyright © 2011-2022 走看看