1
0
mirror of https://github.com/restoreddev/phpapprentice.git synced 2025-10-25 20:06:05 +02:00

Removed docs folder from repository and moved build to separate branch

This commit is contained in:
Andrew Davis
2018-09-02 13:03:36 -05:00
parent bec890cc69
commit 676e090b41
18 changed files with 2 additions and 2628 deletions

2
.gitignore vendored
View File

@@ -2,3 +2,5 @@
/vendor /vendor
/node_modules /node_modules
/docs

View File

@@ -1 +0,0 @@
phpapprentice.com

View File

@@ -1,84 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Arithmetic</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Arithmetic</h1>
<h3 class="subtitle">Doing math like a pro</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">Now that we know how to create variables, let's look at doing some math.</div><div class="code"><pre><code class="language-php">$a = 1;
$b = 2;
</code></pre></div><div class="doc">To add two values, use the plus symbol.</div><div class="code"><pre><code class="language-php">$c = $a + $b;
</code></pre></div><div class="doc">To subtract, use the minus symbol.</div><div class="code"><pre><code class="language-php">$c = $b - $a;
</code></pre></div><div class="doc">To multiply two values, use an asterisk.</div><div class="code"><pre><code class="language-php">echo $a * $b;
</code></pre></div><div class="doc">To divide values, use a forward slash.</div><div class="code"><pre><code class="language-php">echo $b / $a;
</code></pre></div><div class="doc">PHP uses the percent symbol for calculating the modulus of two numbers. The modulus is calculated by dividing two numbers and returning the remainder of the result. So, in this example, the value of $modulo will be 0.</div><div class="code"><pre><code class="language-php">$modulo = 10 % 5;
</code></pre></div><div class="doc">You can also use double asterisks to calculate a number to the power of another number. The following statement will print 25.</div><div class="code"><pre><code class="language-php">echo 5 ** 2;
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/variables.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
<a href="/comparisons.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,80 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Arrays</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Arrays</h1>
<h3 class="subtitle">Time to make a list</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">There are two ways to create an array. First, you can use the array construct to pass in values separated by commas and it will return an array.</div><div class="code"><pre><code class="language-php">$taskList = array('grocery store', 'change car oil');
</code></pre></div><div class="doc">Second, you can surround the list in square brackets. This style is the most common and recommended form of creating an array.</div><div class="code"><pre><code class="language-php">$groceryList = ['bread', 'milk', 'eggs'];
</code></pre></div><div class="doc">PHP will automatically assign index keys for each value in an array starting with 0. So, to access a value in an array you will pass the key number into brackets after the variable name.</div><div class="code"><pre><code class="language-php">echo $groceryList[0] . &quot;\n&quot;;
echo $groceryList[1] . &quot;\n&quot;;
</code></pre></div><div class="doc">You can also assign keys in an array using numbers or strings. It is very common to create an array with string keys. The pattern is called an associative array or a map.</div><div class="code"><pre><code class="language-php">$car = ['make' =&gt; 'Toyota', 'model' =&gt; 'Camry'];
</code></pre></div><div class="doc">To access the value in an associative array, just use the string key in brackets after the variable name.</div><div class="code"><pre><code class="language-php">echo $car['model'] . &quot;\n&quot;;
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/loops.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
<a href="/functions.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,78 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Basics</title>
<meta name="description" content="Let us get started with the basics.">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Basics</h1>
<h3 class="subtitle">Getting started</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">In the tradition of our ancestors, let's start with a hello world program. All PHP files must start with a &lt;?php tag unless it is for a html template. (We will learn about html templates later.)</div><div class="code"><pre><code class="language-php">echo &quot;Hello World!\n&quot;;
</code></pre></div><div class="doc">There is a lot going on in this statement so let's work through it.</div><div class="code"><pre><code class="language-php">
</code></pre></div><div class="doc">First, the echo keyword tells PHP to output some text.</div><div class="code"><pre><code class="language-php">echo 'I am some text';
</code></pre></div><div class="doc">Second, PHP stores text in strings.</div><div class="code"><pre><code class="language-php">
</code></pre></div><div class="doc">To write a string, you surround letters with single or double quotes. The difference between single quoted strings and double quoted strings is that double quoted strings can hold special characters like \n which tells PHP to start a new line.</div><div class="code"><pre><code class="language-php">'I am a string';
&quot;\nI am a string on a new line&quot;;
</code></pre></div><div class="doc">Third, all lines of code in PHP must end in a semi-colon.</div><div class="code"><pre><code class="language-php">echo &quot;No semi-colon is a no-no\n&quot;;
</code></pre></div><div class="doc">Using semi-colons means we can write multiple statements on one line.</div><div class="code"><pre><code class="language-php">echo 'Hello'; echo &quot; World\n&quot;;
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/variables.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,90 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Boolean Logic</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Boolean Logic</h1>
<h3 class="subtitle">Is it a yes or a no?</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">Boolean logic is used to combine booleans to return another boolean.</div><div class="code"><pre><code class="language-php">
</code></pre></div><div class="doc">Using double ampersands tells PHP to check if both values are true. If so, it will return true. If not, it will return false.</div><div class="code"><pre><code class="language-php">$a = true;
$b = true;
$c = false;
</code></pre></div><div class="doc">Returns true.</div><div class="code"><pre><code class="language-php">$a &amp;&amp; $b;
</code></pre></div><div class="doc">Returns false.</div><div class="code"><pre><code class="language-php">$a &amp;&amp; $c;
</code></pre></div><div class="doc">Using two pipe characters checks if either value is true. Then, it will return true. If both values are false, the PHP returns false.</div><div class="code"><pre><code class="language-php">$a = true;
$b = false;
$c = false;
$d = true;
</code></pre></div><div class="doc">Returns true.</div><div class="code"><pre><code class="language-php">$a || $b;
</code></pre></div><div class="doc">Returns false.</div><div class="code"><pre><code class="language-php">$b || $c;
</code></pre></div><div class="doc">Returns true.</div><div class="code"><pre><code class="language-php">$a || $d;
</code></pre></div><div class="doc">Using an exclamation point returns the value flipped.</div><div class="code"><pre><code class="language-php">$d = true;
</code></pre></div><div class="doc">Outputs false.</div><div class="code"><pre><code class="language-php">echo !$d;
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/comparisons.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
<a href="/conditionals.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,94 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Classes</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Classes</h1>
<h3 class="subtitle">Object-oriented programming</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">Classes allow you to define your own data types. All classes start with the class keyword followed by the name of the class and opening and closing curly braces.</div><div class="code"><pre><code class="language-php">class Car
{
}
</code></pre></div><div class="doc">To create an instance of a class, you use the &quot;new&quot; keyword in front of the class name with parentheses.</div><div class="code"><pre><code class="language-php">$car = new Car();
</code></pre></div><div class="doc">A class can define attributes and methods. An attribute is a piece of data stored on the class instance. You can define an attribute by adding the word &quot;public&quot; and a variable name inside the class definition.</div><div class="code"><pre><code class="language-php">class Bicycle
{
public $color;
}
</code></pre></div><div class="doc">Then, when you create an instance of the class, you can set and use the color attribute on the bicycle using &quot;-&gt;&quot;.</div><div class="code"><pre><code class="language-php">$bike = new Bicycle();
$bike-&gt;color = 'Blue';
echo $bike-&gt;color . &quot;\n&quot;;
</code></pre></div><div class="doc">A method is a function attached to the class. You can add a method to a class by using the &quot;public&quot; keyword followed by the function. A method can access the attributes and methods of the instance using the &quot;$this&quot; variable.</div><div class="code"><pre><code class="language-php">class Tricycle
{
public $color;
public function echoColor()
{
echo $this-&gt;color . &quot;\n&quot;;
}
}
$bike = new Tricycle();
$bike-&gt;color = 'Red';
$bike-&gt;echoColor();
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/functions.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,91 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Comparisons</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Comparisons</h1>
<h3 class="subtitle">Equality checking</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">A boolean is a value that is always 0 or 1, yes or no, on or off. In PHP, a boolean is represented by the words true and false. While programming, you will often want to know if something is true or false.</div><div class="code"><pre><code class="language-php">$a = true;
$b = false;
</code></pre></div><div class="doc">There are many constructs and functions that will return a boolean. To start, let's look at comparisons.</div><div class="code"><pre><code class="language-php">$one = 1;
$two = 2;
</code></pre></div><div class="doc">Double equals checks if two values are equal. This statement will return false.</div><div class="code"><pre><code class="language-php">$one == $two;
</code></pre></div><div class="doc">An exclamation point and equal sign check if two values are not equal. This statement will return true.</div><div class="code"><pre><code class="language-php">$one != $two;
</code></pre></div><div class="doc">You can use greater than and less than symbols to check for comparisons too. This statement will return false.</div><div class="code"><pre><code class="language-php">$one > $two;
</code></pre></div><div class="doc">This statement will return true.</div><div class="code"><pre><code class="language-php">$one < $two;
</code></pre></div><div class="doc">If you combine a greater than or less than symbol with an equal, it will check if the value is greater or less than or equal to another value.</div><div class="code"><pre><code class="language-php">$one &lt;= $two;
$one &gt;= $two;
</code></pre></div><div class="doc">You can also check that two values are equal and of the same type by using three equal signs.</div><div class="code"><pre><code class="language-php">
</code></pre></div><div class="doc">This returns true.</div><div class="code"><pre><code class="language-php">1 == '1';
</code></pre></div><div class="doc">This returns false.</div><div class="code"><pre><code class="language-php">1 === '1';
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/arithmetic.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
<a href="/boolean-logic.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,119 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Conditionals</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Conditionals</h1>
<h3 class="subtitle">Checking the if before the what</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">When writing code, there will be times when you need to perform actions only under certain circumstances. There are several ways to control execution in PHP. We will start with an if statement.</div><div class="code"><pre><code class="language-php">$animal = 'cow';
if ($animal == 'cow') {
echo &quot;Moooooo.....\n&quot;;
}
</code></pre></div><div class="doc">All conditionals check to see if a statement evaluates to true or false. In the case above, since $animal equals 'cow', the statement returns true and the contents of the if statement are executed.</div><div class="code"><pre><code class="language-php">
</code></pre></div><div class="doc">An if statement can have multiple conditions chained together. If the first if statement returns false, then PHP will check each elseif. If none of the checks return true, then the else block will be executed.</div><div class="code"><pre><code class="language-php">$animal = 'bird';
if ($animal == 'dog') {
echo &quot;Woof! 🐶\n&quot;;
} elseif ($animal == 'cat') {
echo &quot;Meow!? 🐱\n&quot;;
} elseif ($animal == 'bird') {
echo &quot;Chirp! 🐦\n&quot;;
} else {
echo &quot;I am not a dog, cat or bird\n&quot;;
}
</code></pre></div><div class="doc">An alternative to the if statement is the switch. A switch statement has multiple cases to check if the value in parentheses equals something. In this statement, since $food equals 'apples', the switch will echo &quot;Eating an apple&quot;. The default case will be run if no other case evaluates to true, like an else statement.</div><div class="code"><pre><code class="language-php">$food = 'apples';
switch ($food) {
case 'apples':
echo &quot;Eating an apple\n&quot;;
break;
case 'oranges':
echo &quot;Eating an orange\n&quot;;
break;
case 'peaches':
echo &quot;Eating a peach\n&quot;;
break;
default:
echo &quot;No food, I am hungry\n&quot;;
}
</code></pre></div><div class="doc">Breaks are a special keyword that tell PHP to stop execution once a case passes. If you do not use a break, PHP will continue to execute all following cases. In this switch, both &quot;Drinking water&quot; and &quot;Drinking tea&quot; will be executed since there is no break in the 'water' case.</div><div class="code"><pre><code class="language-php">$drink = 'water';
switch ($drink) {
case 'water':
echo &quot;Drinking water\n&quot;;
case 'tea':
echo &quot;Drinking tea\n&quot;;
break;
}
</code></pre></div><div class="doc">PHP also supports single line conditionals called a ternary. In a ternary, the condition is followed by a question mark before the value that should be returned if the condition is true and then another colon and a value to return if the condition is false.</div><div class="code"><pre><code class="language-php">$language = 'english';
echo $language == 'spanish' ? &quot;hola\n&quot; : &quot;hello\n&quot;;
</code></pre></div><div class="doc">Lastly, there is another form of a ternary that checks if a value is set and then returns the value to the right of two question marks if value is null.</div><div class="code"><pre><code class="language-php">echo $IDoNotExist ?? &quot;Variable not set\n&quot;;
</code></pre></div><div class="doc">You can also chain multiple checks in a row.</div><div class="code"><pre><code class="language-php">$IExist = &quot;Variable exists\n&quot;;
echo $IDoNotExist ?? $IExist ?? &quot;Neither variable is set\n&quot;;
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/boolean-logic.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
<a href="/loops.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,69 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>PHP Apprentice - Credits</title>
<meta name="description" content="A site for learning how to use PHP">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="container center">
<div class="grid-toc">
<div>
<h1>Credits</h1>
<p>
PHP Apprentice was inspired by
<a href="https://gobyexample.com/">Go By Example</a> and by <a href="https://elixirschool.com/">Elixir School</a>. Both sites offer excellent, quality documentation in Go and Elixir and I want PHP Apprentice to provide the same
experience for the PHP programming language.
</p>
<p>
Source Links:
<ul>
<li><a href="https://secure.php.net/" target="_blank">php.net</a></li>
<li><a href="https://www.phptherightway.com/" target="_blank">PHP The Right Way</a></li>
</ul>
</p>
<p>
PHP Apprentice was built using several open source projects.
Thank you to each of these maintainers for providing great libraries!
<ul>
<li><a href="https://prismjs.com/" target="_blank">Prism.js</a></li>
<li><a href="https://www.zondicons.com/" target="_blank">Zondicons by Steve Schoger</a></li>
<li><a href="https://postcss.org/" target="_blank">PostCSS</a></li>
<li><a href="https://symfony.com/doc/current/components/console.html" target="_blank">Symfony CLI</a></li>
<li><a href="https://symfony.com/doc/current/frontend.html" target="_blank">Symfony Encore</a></li>
</ul>
</p>
</div>
<div>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,418 +0,0 @@
/*
Solarized Color Schemes originally by Ethan Schoonover
http://ethanschoonover.com/solarized
Ported for PrismJS by Hector Matos
Website: https://krakendev.io
Twitter Handle: https://twitter.com/allonsykraken)
*/
/*
SOLARIZED HEX
--------- -------
base03 #002b36
base02 #073642
base01 #586e75
base00 #657b83
base0 #839496
base1 #93a1a1
base2 #eee8d5
base3 #fdf6e3
yellow #b58900
orange #cb4b16
red #dc322f
magenta #d33682
violet #6c71c4
blue #268bd2
cyan #2aa198
green #859900
*/
code[class*="language-"],
pre[class*="language-"] {
color: #657b83; /* base00 */
font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
text-align: left;
white-space: pre;
word-spacing: normal;
word-break: normal;
word-wrap: normal;
line-height: 1.5;
-moz-tab-size: 4;
-o-tab-size: 4;
tab-size: 4;
-webkit-hyphens: none;
-ms-hyphens: none;
hyphens: none;
}
pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection,
code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection {
background: #073642; /* base02 */
}
pre[class*="language-"]::selection, pre[class*="language-"] ::selection,
code[class*="language-"]::selection, code[class*="language-"] ::selection {
background: #073642; /* base02 */
}
/* Code blocks */
pre[class*="language-"] {
padding: 1em;
margin: .5em 0;
overflow: auto;
border-radius: 0.3em;
}
:not(pre) > code[class*="language-"],
pre[class*="language-"] {
background-color: #fdf6e3; /* base3 */
}
/* Inline code */
:not(pre) > code[class*="language-"] {
padding: .1em;
border-radius: .3em;
}
.token.comment,
.token.prolog,
.token.doctype,
.token.cdata {
color: #93a1a1; /* base1 */
}
.token.punctuation {
color: #586e75; /* base01 */
}
.namespace {
opacity: .7;
}
.token.property,
.token.tag,
.token.boolean,
.token.number,
.token.constant,
.token.symbol,
.token.deleted {
color: #268bd2; /* blue */
}
.token.selector,
.token.attr-name,
.token.string,
.token.char,
.token.builtin,
.token.url,
.token.inserted {
color: #2aa198; /* cyan */
}
.token.entity {
color: #657b83; /* base00 */
background: #eee8d5; /* base2 */
}
.token.atrule,
.token.attr-value,
.token.keyword {
color: #859900; /* green */
}
.token.function,
.token.class-name {
color: #b58900; /* yellow */
}
.token.regex,
.token.important,
.token.variable {
color: #cb4b16; /* orange */
}
.token.important,
.token.bold {
font-weight: bold;
}
.token.italic {
font-style: italic;
}
.token.entity {
cursor: help;
}
body {
font-family: Palatino, "Palatino Linotype", "Palatino LT STD", "Book Antiqua", Georgia, serif;
font-size: 16px;
padding-top: 1em;
padding-bottom: 1em;
}
pre, code {
font-family: Consolas, monaco, monospace;
font-size: 16px;
margin: 0 !important;
border-radius: 0 !important;
padding-top: 0.5em !important;
padding-bottom: 0.5em !important;
}
a {
color: #2AA198; /* #4078f2 */
text-decoration: none;
}
a:hover {
text-decoration: underline;
color: #1D6E68;
}
p {
max-width: 40em;
line-height: 1.5;
}
h1, h2, h3, h4 {
margin: 1.414em 0 0.5em;
font-weight: inherit;
line-height: 1.2;
}
h1 {
margin-top: 0;
font-size: 2.441em;
}
h2 {font-size: 1.953em;}
h3 {font-size: 1.563em;}
h4 {font-size: 1.25em;}
small, .font_small {font-size: 0.8em;}
button {
font-size: 1em;
background-color: transparent;
border: 0;
cursor: pointer;
padding: 0;
color: #2AA198;
}
button:hover {
color: #1D6E68;
}
button .icon {
vertical-align: middle;
}
button .icon svg {
fill: #2AA198;
}
button:hover .icon svg {
fill: #1D6E68;
}
.button {
background-color: #2AA198;
color: #FFF;
padding: 0.5em 1em;
border-radius: 1em;
}
.button:hover {
color: #FFF;
background-color: #1D6E68;
text-decoration: none;
}
.button .icon {
vertical-align: middle;
}
.button .icon svg {
fill: #FFF;
}
.clearfix:after {
content: "";
display: table;
clear: both;
}
.container {
width: 90%;
margin-left: auto;
margin-right: auto;
}
@media only screen and (min-width: 33.75em) { /* 540px */
.container {
width: 80%;
}
}
.center {
margin-left: auto;
margin-right: auto;
}
.right {
float: right;
}
.doc {
padding: 0.5em 0;
}
.subtitle {
margin-top: 0;
}
.description {
max-width: 25em;
}
.grid-code {
display: grid;
grid-template-columns: 400px 1fr;
grid-column-gap: 3em;
}
.grid-code .code {
background-color: #FDF6E3;
}
.grid-toc {
display: grid;
grid-template-columns: 2fr 1fr;
grid-column-gap: 3em;
}
.navigate-links {
margin: 1em 0;
float: right;
}
.navigate-links .icon {
vertical-align: middle;
}
.navigate-links .icon svg {
fill: #2AA198;
}
.navigate-links:hover .icon svg {
fill: #1D6E68;
}
.navigate-links a {
margin-left: 1em;
}
.navigate-links a:hover {
text-decoration: none;
}
.table-of-contents {
padding: 2em;
}
.table-of-contents ol {
margin: 1em 0;
padding-left: 1em;
}
.table-of-contents .section-title {
font-weight: bold;
font-size: 0.8em;
margin-top: 1em;
}
.icon {
width: 1em;
display: inline-block;
}
.home-title-wrapper {
display: grid;
grid-template-columns: 175px 1fr;
grid-template-rows: 1fr 1fr;
}
.home-title {
}
.home-subtitle {
margin-top: 0;
grid-column-start: 2;
grid-column-end: 3;
}
.home-logo {
grid-row-start: 1;
grid-row-end: 3;
}
.home-logo svg {
width: 150px;
height: 100px;
}
.menu {
margin-left: 2em;
margin-bottom: 1em;
}
.modal {
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
z-index: 50;
overflow: auto;
background-color: rgba(0, 0, 0, .4);
}
.modal-content {
display: block;
position: relative;
padding: 1em;
background-color: #FFF;
max-width: 15em;
height: 100%;
-webkit-animation-name: animateleft;
animation-name: animateleft;
-webkit-animation-duration: .4s;
animation-duration: .4s;
overflow: scroll;
box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.4);
}
.closed {
display: none;
}
@-webkit-keyframes animateleft {
from {left: -300px; opacity: 0}
to {left: 0; opacity: 1}
}
@keyframes animateleft {
from {left: -300px; opacity: 0}
to {left: 0; opacity: 1}
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

View File

@@ -1,95 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Functions</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Functions</h1>
<h3 class="subtitle">Reusable code</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">A function allows you to store code under a name and then execute that code later.</div><div class="code"><pre><code class="language-php">
</code></pre></div><div class="doc">A function always starts with the function keyword followed by the name with parentheses and then opening and closing curly braces around the code.</div><div class="code"><pre><code class="language-php">function hello_world() {
echo &quot;hello world\n&quot;;
}
</code></pre></div><div class="doc">To call the function, use the function name with parentheses.</div><div class="code"><pre><code class="language-php">hello_world();
</code></pre></div><div class="doc">You can set up values to be passed into a function. To do so, write variables in between the function parentheses. Each one should be separated by a comma.</div><div class="code"><pre><code class="language-php">function greet($firstname, $lastname) {
echo "hello $firstname $lastname\n";
}
</code></pre></div><div class="doc">Then, you can pass in values when calling a function. In the greet function, 'John' is assigned to $firstname and 'Smith' is assigned to $lastname.</div><div class="code"><pre><code class="language-php">greet('John', 'Smith');
</code></pre></div><div class="doc">You can also return a value from a function. You can only return a single value from a function.</div><div class="code"><pre><code class="language-php">function capitalize($value) {
return strtoupper($value);
}
</code></pre></div><div class="doc">When calling a function, it will output the return value which you can load into a variable.</div><div class="code"><pre><code class="language-php">$animal = capitalize('dog');
echo "$animal\n";
</code></pre></div><div class="doc">You can also create nameless functions called closures. Closures can be stored in variables or passed into other functions.</div><div class="code"><pre><code class="language-php">$sum = function ($a, $b) {
return $a + $b;
};
</code></pre></div><div class="doc">You can execute a closure by putting parentheses after the variable.</div><div class="code"><pre><code class="language-php">echo $sum(1, 2) . &quot;\n&quot;;
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/arrays.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
<a href="/classes.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,109 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>PHP Apprentice</title>
<meta name="description" content="A site for learning how to use PHP">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="container center">
<div class="grid-toc">
<div>
<div class="home-title-wrapper">
<div class="home-logo"><?xml version="1.0" encoding="UTF-8"?>
<svg width="404px" height="249px" viewBox="0 0 404 249" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<!-- Generator: Sketch 49.3 (51167) - http://www.bohemiancoding.com/sketch -->
<title>elephant</title>
<desc>Created with Sketch.</desc>
<defs>
<path d="M114.406262,33.0409234 C116.906654,33.0409234 198.587086,33.0409234 212.851562,33.0409234 C236.23173,33.0409234 290.966457,24.8360253 302.9375,21.828125 C322.709617,16.8600902 345.780295,41.1710486 350.739426,66.2834373 C355.388936,89.8279414 351.557615,107.060167 350.739426,117.478001 C348.492267,146.090655 340.913827,171.751032 340.913827,188.521289 C340.913827,211.397578 342.398654,228.60813 345.368307,240.152946 C338.345502,243.384315 332.63113,245 328.225191,245 C323.819252,245 319.466187,243.384315 315.165998,240.152946 C315.165998,212.852821 315.165998,195.642269 315.165998,188.521289 C315.165998,182.659437 313.041474,171.488839 308.792425,155.009494 C278.81585,157.935469 251.486979,159.893283 226.805814,160.882937 C202.124648,161.87259 177.935757,159.914776 154.23914,155.009494 C151.904793,170.439973 150.468074,183.375856 149.928982,193.817144 C149.389891,204.258431 148.391339,219.703699 146.933325,240.152946 C138.57305,243.384315 132.573934,245 128.935979,245 C125.298024,245 120.454785,243.384315 114.406262,240.152946 C121.029663,211.242836 124.190445,189.722491 123.888609,175.59191 C122.851956,127.060632 111.761968,33.0409234 114.406262,33.0409234 Z" id="path-1"></path>
<filter x="-2.7%" y="-2.0%" width="103.8%" height="104.0%" filterUnits="objectBoundingBox" id="filter-2">
<feMorphology radius="0.5" operator="dilate" in="SourceAlpha" result="shadowSpreadOuter1"></feMorphology>
<feOffset dx="-2" dy="0" in="shadowSpreadOuter1" result="shadowOffsetOuter1"></feOffset>
<feGaussianBlur stdDeviation="1" in="shadowOffsetOuter1" result="shadowBlurOuter1"></feGaussianBlur>
<feComposite in="shadowBlurOuter1" in2="SourceAlpha" operator="out" result="shadowBlurOuter1"></feComposite>
<feColorMatrix values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0" type="matrix" in="shadowBlurOuter1"></feColorMatrix>
</filter>
<path d="M123.708835,0.204671096 C110.38422,-0.782948431 96.8541352,1.80367512 83.1185794,7.96454174 C70.5914337,12.5905258 61.8564763,19.2306573 56.9137071,27.8849362 C45.3780726,48.0826419 45.2190029,54.1139776 45.2190029,74.89832 C45.2190029,80.5496319 45.2190029,94.2775295 45.2190029,116.082013 C44.8941776,135.814054 42.9028153,149.847335 39.2449159,158.181856 C35.7666671,166.107044 22.7617193,171.939345 0.23007254,175.678759 C0.0766908466,178.530744 -4.04672828e-16,180.785883 0,182.444176 C-4.04672828e-16,184.102469 0.742211413,186.619924 2.22663424,189.996543 C19.3683356,190.134613 33.6991251,186.137222 45.2190029,178.004371 C58.0689401,168.932519 56.2252902,163.797983 62.486142,147.454285 C66.2191971,137.709297 68.3704403,127.251873 68.9398717,116.082013 C98.4645478,120.955097 116.720869,123.391639 123.708835,123.391639 C134.190784,123.391639 148.793717,120.923091 160.10709,103.338129 C171.533853,85.5769196 172.420694,75.0592376 174.453335,67.1621734 C177.277215,56.1910529 186,34.1766174 186,21.1547558 C186,8.13289413 144.421355,1.73988173 123.708835,0.204671096 Z" id="path-3"></path>
<filter x="-1.9%" y="-1.3%" width="104.8%" height="104.7%" filterUnits="objectBoundingBox" id="filter-4">
<feMorphology radius="0.5" operator="dilate" in="SourceAlpha" result="shadowSpreadOuter1"></feMorphology>
<feOffset dx="1" dy="2" in="shadowSpreadOuter1" result="shadowOffsetOuter1"></feOffset>
<feGaussianBlur stdDeviation="1" in="shadowOffsetOuter1" result="shadowBlurOuter1"></feGaussianBlur>
<feComposite in="shadowBlurOuter1" in2="SourceAlpha" operator="out" result="shadowBlurOuter1"></feComposite>
<feColorMatrix values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0" type="matrix" in="shadowBlurOuter1"></feColorMatrix>
</filter>
</defs>
<g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
<g id="Elephant" transform="translate(-120.000000, -62.000000)">
<g id="elephant" transform="translate(122.000000, 63.000000)">
<path d="M292,154 L292,229.687017 C297.80012,232.562339 302.466787,234 306,234 C309.533213,234 314.19988,232.562339 320,229.687017 L320,154 L292,154 Z" id="Path-3" stroke="#979797" fill="#D8D8D8"></path>
<path d="M113.089613,112 C112.215697,146.301082 110.868891,171.05041 109.049195,186.247987 C107.229499,201.445563 103.879767,215.920359 99,229.672376 C104.837247,232.557459 109.533784,234 113.089613,234 C116.645442,234 121.34198,232.557459 127.179226,229.672376 L134,112 L113.089613,112 Z" id="Path-3-Copy" stroke="#979797" fill="#D8D8D8"></path>
<g id="Path">
<use fill="black" fill-opacity="1" filter="url(#filter-2)" xlink:href="#path-1"></use>
<use stroke="#979797" stroke-width="1" fill="#D8D8D8" fill-rule="evenodd" xlink:href="#path-1"></use>
</g>
<g id="Path-2">
<use fill="black" fill-opacity="1" filter="url(#filter-4)" xlink:href="#path-3"></use>
<use stroke="#979797" stroke-width="1" fill="#D8D8D8" fill-rule="evenodd" xlink:href="#path-3"></use>
</g>
<circle id="Oval" fill="#000000" cx="77" cy="76" r="5"></circle>
<path d="M394.04451,154.695284 C387.335643,135.817928 382.463422,123.3603 379.427845,117.322398 C376.392268,111.284497 366.955141,94.8960125 351.116464,68.1569449 L353,83.4050009 C362.468082,99.4723027 368.913046,110.778102 372.334893,117.322398 C380.679064,133.280662 386.198146,152.11787 388.617876,158.078886 C390.422602,162.524839 392.314008,171.103712 394.04451,185.164806 C394.940381,192.444154 397.167522,203.5 399.948259,203.5 C402.726203,203.5 400.982103,193.180619 399.948259,185.164806 C399.25903,179.820931 397.291114,169.664424 394.04451,154.695284 Z" id="Path-4" stroke="#979797" fill="#D8D8D8"></path>
</g>
</g>
</g>
</svg></div>
<h1 class="home-title">PHP Apprentice <em>(beta)</em></h1>
<h3 class="home-subtitle">A site for learning how to use PHP</h3>
</div>
<p>
The goal of PHP Apprentice is to be an easy to understand resource for learning how to write good code in the PHP programming language. There are a lot of PHP tutorials on the internet that use outdated libraries, insecure programming practices or inefficient code. I want this site to show how to write PHP code with quality.
</p>
<p>
The site currently has content for learning the basics of PHP. In the future, more pages will be added for more advanced topics like building websites, database integration and security.
</p>
<p>
PHP Apprentice is currently a work in progress (hence "beta" is included in the title). If you would like to contribute or request a certain discussion topic, checkout the <a href="https://github.com/restoreddev/phpapprentice" target="_blank">GitHub repository</a>.
</p>
<p>
To get started, you will need to install PHP 7.1, have a text editor and open your terminal.
Each example in PHP Apprentice can by typed into a PHP file and executed in the terminal.
Let's get started! 😃
</p>
<a href="/basics.html" class="button">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M6 4H5a1 1 0 1 1 0-2h11V1a1 1 0 0 0-1-1H4a2 2 0 0 0-2 2v16c0 1.1.9 2 2 2h12a2 2 0 0 0 2-2V5a1 1 0 0 0-1-1h-7v8l-2-2-2 2V4z"/></svg></div>
Open First Chapter
</a>
</div>
<div>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</div>
</body>
</html>

File diff suppressed because it is too large Load Diff

View File

@@ -1,106 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Loops</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Loops</h1>
<h3 class="subtitle">Increase your repetitions</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">A loop tells PHP to run a block of code more than once. A classic loop is a while loop. A &quot;while&quot; loop will continue to run the block of code as long as the value in parentheses is true.</div><div class="code"><pre><code class="language-php">$num = 5;
while ($num > 0) {
echo "While loop $num\n";
--$num;
}
</code></pre></div><div class="doc">A &quot;do while&quot; loop is similar to a &quot;while&quot; loop except it always runs at least one iteration. In a classic &quot;while&quot; loop, no iterations may be executed if the value in parentheses is false. In a &quot;do while&quot;, the boolean check is not done until after the execution of an iteration.</div><div class="code"><pre><code class="language-php">$num = 0;
do {
echo "Do while $num\n";
++$num;
} while ($num < 5);
</code></pre></div><div class="doc">&quot;for&quot; loops allow you to create a more concise while loop. Inside the parentheses, the left section creates a variable before the loop starts, the middle section is the check that is done at the beginning of each loop and the third section is executed after each loop.</div><div class="code"><pre><code class="language-php">for ($i = 0; $i < 10; $i++) {
echo "For loop $i\n";
}
</code></pre></div><div class="doc">A &quot;foreach&quot; loop allows you to easily loop over an array. An array is a list of data stored together. The &quot;as&quot; keyword lets you assign a variable to the value in the array for the current iteration of the loop.</div><div class="code"><pre><code class="language-php">$set = [1, 2, 3, 4, 5];
foreach ($set as $num) {
echo "Array value $num\n";
}
</code></pre></div><div class="doc">In loops, you can use the keyword &quot;break&quot; to stop the loop execution no matter how many more iterations should run.</div><div class="code"><pre><code class="language-php">$values = ['one', 'two', 'three'];
foreach ($values as $value) {
if ($value === 'two') {
break;
}
echo "Break $value\n";
}
</code></pre></div><div class="doc">The &quot;continue&quot; keyword stops executing the current loop iteration, but then allows the loop to continue with other iterations.</div><div class="code"><pre><code class="language-php">$values = ['one', 'skip', 'three'];
foreach ($values as $value) {
if ($value === 'skip') {
continue;
}
echo "Continue $value\n";
}
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/conditionals.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
<a href="/arrays.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>

View File

@@ -1,4 +0,0 @@
{
"js/site.js": "/js/site.js",
"css/site.css": "/css/site.css"
}

View File

@@ -1,87 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Variables</title>
<meta name="description" content="">
<link rel="stylesheet" href="/css/site.css">
<link rel="icon" href="/favicon-32.png">
<script src="/js/site.js"></script>
</head>
<body>
<div class="menu">
<button class="menu-button" title="Open Menu">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"/></svg></div>
Menu
</button>
</div>
<div class="container center">
<h1>Variables</h1>
<h3 class="subtitle">The building blocks of PHP</h3>
<div class="grid-code"><div class="doc"></div><div class="code"><pre><code class="language-php">&lt;?php
</code></pre></div><div class="doc">The variable is the basic building block of any programming language. In PHP, all variables start with a dollar sign.</div><div class="code"><pre><code class="language-php">$greeting;
</code></pre></div><div class="doc">To set data in a variable, you put an equals sign after it and some data.</div><div class="code"><pre><code class="language-php">$greeting = 'Hello World!';
</code></pre></div><div class="doc">Once you create a variable, you can use it again in other commands and functions.</div><div class="code"><pre><code class="language-php">echo $greeting;
</code></pre></div><div class="doc">After the dollar sign, a PHP variable must have an alphabetic character or underscore. Also, variables are case sensitive.</div><div class="code"><pre><code class="language-php">$_var = 'I am a variable with an underscore!';
$Var = 'I am a variable with a capital letter!';
$var = 'I am a new variable';
</code></pre></div><div class="doc">Variables can hold many different types of data, but there are four simple ones you can try now. An int is a number without a decimal place. A float is a number with a decimal place. A boolean can be two values: true or false. Last, there is a string, a collection of characters.</div><div class="code"><pre><code class="language-php">$int = 1;
$float = 100.10;
$bool = true;
$string = 'I am a string';
</code></pre></div><div class="doc">In other programming languages, you have to write what type of data the variable will contain. PHP keeps it simple by allowing you to put any type of data in a variable, including already used variables.</div><div class="code"><pre><code class="language-php">$number = 1;
$number = 'one';
</code></pre></div></div>
<div class="clearfix"></div>
<div class="navigate-links">
<a href="/basics.html" title="Previous">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 20a10 10 0 1 1 0-20 10 10 0 0 1 0 20zm8-10a8 8 0 1 0-16 0 8 8 0 0 0 16 0zM7.46 9.3L11 5.75l1.41 1.41L9.6 10l2.82 2.83L11 14.24 6.76 10l.7-.7z"/></svg></div>
Previous
</a>
<a href="/arithmetic.html" title="Next">
Next
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M10 0a10 10 0 1 1 0 20 10 10 0 0 1 0-20zM2 10a8 8 0 1 0 16 0 8 8 0 0 0-16 0zm10.54.7L9 14.25l-1.41-1.41L10.4 10 7.6 7.17 9 5.76 13.24 10l-.7.7z"/></svg></div>
</a>
</div>
</div>
<div class="modal closed">
<div class="modal-content">
<button class="modal-button right" title="Close">
<div class="icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><path d="M2.93 17.07A10 10 0 1 1 17.07 2.93 10 10 0 0 1 2.93 17.07zm1.41-1.41A8 8 0 1 0 15.66 4.34 8 8 0 0 0 4.34 15.66zm9.9-8.49L11.41 10l2.83 2.83-1.41 1.41L10 11.41l-2.83 2.83-1.41-1.41L8.59 10 5.76 7.17l1.41-1.41L10 8.59l2.83-2.83 1.41 1.41z"/></svg></div>
</button>
<div class="table-of-contents">
<h4>Table of Contents</h4>
<a href="/index.html">Preface</a>
<ol>
<li><a href="/basics.html">Basics</a></li>
<li><a href="/variables.html">Variables</a></li>
<li><a href="/arithmetic.html">Arithmetic</a></li>
<li><a href="/comparisons.html">Comparisons</a></li>
<li><a href="/boolean-logic.html">Boolean Logic</a></li>
<li><a href="/conditionals.html">Conditionals</a></li>
<li><a href="/loops.html">Loops</a></li>
<li><a href="/arrays.html">Arrays</a></li>
<li><a href="/functions.html">Functions</a></li>
<li><a href="/classes.html">Classes</a></li>
</ol>
<a href="/credits.html">Credits</a>
</div>
</div>
</div>
</body>
</html>