Derek Allard | 2067d1a | 2008-11-13 22:59:24 +0000 | [diff] [blame] | 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> |
| 2 | <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> |
| 3 | <head> |
| 4 | |
| 5 | <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> |
| 6 | <title>Array Helper : CodeIgniter User Guide</title> |
| 7 | |
| 8 | <style type='text/css' media='all'>@import url('../userguide.css');</style> |
| 9 | <link rel='stylesheet' type='text/css' media='all' href='../userguide.css' /> |
| 10 | |
| 11 | <script type="text/javascript" src="../nav/nav.js"></script> |
| 12 | <script type="text/javascript" src="../nav/prototype.lite.js"></script> |
| 13 | <script type="text/javascript" src="../nav/moo.fx.js"></script> |
| 14 | <script type="text/javascript" src="../nav/user_guide_menu.js"></script> |
| 15 | |
| 16 | <meta http-equiv='expires' content='-1' /> |
| 17 | <meta http-equiv= 'pragma' content='no-cache' /> |
| 18 | <meta name='robots' content='all' /> |
| 19 | <meta name='author' content='ExpressionEngine Dev Team' /> |
| 20 | <meta name='description' content='CodeIgniter User Guide' /> |
| 21 | |
| 22 | </head> |
| 23 | <body> |
| 24 | |
| 25 | <!-- START NAVIGATION --> |
| 26 | <div id="nav"><div id="nav_inner"><script type="text/javascript">create_menu('../');</script></div></div> |
| 27 | <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="Toggle Table of Contents" alt="Toggle Table of Contents" /></a></div> |
| 28 | <div id="masthead"> |
| 29 | <table cellpadding="0" cellspacing="0" border="0" style="width:100%"> |
| 30 | <tr> |
Phil Sturgeon | 9c63d0b | 2011-10-27 01:55:44 +0100 | [diff] [blame] | 31 | <td><h1>CodeIgniter User Guide Version 2.1.0</h1></td> |
Derek Allard | 2067d1a | 2008-11-13 22:59:24 +0000 | [diff] [blame] | 32 | <td id="breadcrumb_right"><a href="../toc.html">Table of Contents Page</a></td> |
| 33 | </tr> |
| 34 | </table> |
| 35 | </div> |
| 36 | <!-- END NAVIGATION --> |
| 37 | |
| 38 | |
| 39 | <!-- START BREADCRUMB --> |
| 40 | <table cellpadding="0" cellspacing="0" border="0" style="width:100%"> |
| 41 | <tr> |
| 42 | <td id="breadcrumb"> |
| 43 | <a href="http://codeigniter.com/">CodeIgniter Home</a> › |
| 44 | <a href="../index.html">User Guide Home</a> › |
| 45 | Array Helper |
| 46 | </td> |
| 47 | <td id="searchbox"><form method="get" action="http://www.google.com/search"><input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.com/user_guide/" />Search User Guide <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" /> <input type="submit" class="submit" name="sa" value="Go" /></form></td> |
| 48 | </tr> |
| 49 | </table> |
| 50 | <!-- END BREADCRUMB --> |
| 51 | |
| 52 | <br clear="all" /> |
| 53 | |
| 54 | |
| 55 | <!-- START CONTENT --> |
| 56 | <div id="content"> |
| 57 | |
| 58 | |
| 59 | <h1>Array Helper</h1> |
| 60 | |
| 61 | <p>The Array Helper file contains functions that assist in working with arrays.</p> |
| 62 | |
| 63 | |
| 64 | <h2>Loading this Helper</h2> |
| 65 | |
| 66 | <p>This helper is loaded using the following code:</p> |
| 67 | <code>$this->load->helper('array');</code> |
| 68 | |
| 69 | <p>The following functions are available:</p> |
| 70 | |
| 71 | <h2>element()</h2> |
| 72 | |
Derek Jones | 4b9c629 | 2011-07-01 17:40:48 -0500 | [diff] [blame] | 73 | <p>Lets you fetch an item from an array. The function tests whether the array index is set and whether it has a value. If |
| 74 | a value exists it is returned. If a value does not exist it returns FALSE, or whatever you've specified as the default value via the third parameter. Example:</p> |
Derek Allard | 2067d1a | 2008-11-13 22:59:24 +0000 | [diff] [blame] | 75 | |
| 76 | <code> |
| 77 | $array = array('color' => 'red', 'shape' => 'round', 'size' => '');<br /> |
| 78 | <br /> |
| 79 | // returns "red"<br /> |
| 80 | echo element('color', $array);<br /> |
| 81 | <br /> |
| 82 | // returns NULL<br /> |
| 83 | echo element('size', $array, NULL); |
| 84 | </code> |
| 85 | |
| 86 | |
| 87 | <h2>random_element()</h2> |
| 88 | |
Derek Jones | 4b9c629 | 2011-07-01 17:40:48 -0500 | [diff] [blame] | 89 | <p>Takes an array as input and returns a random element from it. Usage example:</p> |
Derek Allard | 2067d1a | 2008-11-13 22:59:24 +0000 | [diff] [blame] | 90 | |
| 91 | <code>$quotes = array(<br /> |
| 92 | "I find that the harder I work, the more luck I seem to have. - Thomas Jefferson",<br /> |
| 93 | "Don't stay in bed, unless you can make money in bed. - George Burns",<br /> |
| 94 | "We didn't lose the game; we just ran out of time. - Vince Lombardi",<br /> |
| 95 | "If everything seems under control, you're not going fast enough. - Mario Andretti",<br /> |
| 96 | "Reality is merely an illusion, albeit a very persistent one. - Albert Einstein",<br /> |
| 97 | "Chance favors the prepared mind - Louis Pasteur"<br /> |
| 98 | );<br /> |
| 99 | <br /> |
| 100 | echo random_element($quotes);</code> |
| 101 | |
| 102 | |
Derek Jones | 3a082fd | 2010-10-07 09:38:55 -0500 | [diff] [blame] | 103 | <h2>elements()</h2> |
Derek Allard | 2067d1a | 2008-11-13 22:59:24 +0000 | [diff] [blame] | 104 | |
Derek Jones | 4b9c629 | 2011-07-01 17:40:48 -0500 | [diff] [blame] | 105 | <p>Lets you fetch a number of items from an array. The function tests whether each of the array indices is set. If an index does not exist |
| 106 | it is set to FALSE, or whatever you've specified as the default value via the third parameter. Example:</p> |
Derek Jones | 3a082fd | 2010-10-07 09:38:55 -0500 | [diff] [blame] | 107 | |
| 108 | <code> |
| 109 | $array = array(<br /> |
| 110 | 'color' => 'red',<br /> |
| 111 | 'shape' => 'round',<br /> |
| 112 | 'radius' => '10',<br /> |
| 113 | 'diameter' => '20'<br /> |
| 114 | );<br /> |
| 115 | <br /> |
| 116 | $my_shape = elements(array('color', 'shape', 'height'), $array);<br /> |
| 117 | </code> |
| 118 | |
| 119 | <p>The above will return the following array:</p> |
| 120 | |
| 121 | <code> |
| 122 | array(<br /> |
| 123 | 'color' => 'red',<br /> |
| 124 | 'shape' => 'round',<br /> |
| 125 | 'height' => FALSE<br /> |
| 126 | ); |
| 127 | </code> |
| 128 | |
| 129 | <p>You can set the third parameter to any default value you like:</p> |
| 130 | |
| 131 | <code> |
| 132 | $my_shape = elements(array('color', 'shape', 'height'), $array, NULL);<br /> |
| 133 | </code> |
| 134 | |
| 135 | <p>The above will return the following array:</p> |
| 136 | |
| 137 | <code> |
| 138 | array(<br /> |
| 139 | 'color' => 'red',<br /> |
| 140 | 'shape' => 'round',<br /> |
| 141 | 'height' => NULL<br /> |
| 142 | ); |
| 143 | </code> |
| 144 | |
Derek Jones | 4b9c629 | 2011-07-01 17:40:48 -0500 | [diff] [blame] | 145 | <p>This is useful when sending the <kbd>$_POST</kbd> array to one of your Models. This prevents users from |
Derek Jones | 3a082fd | 2010-10-07 09:38:55 -0500 | [diff] [blame] | 146 | sending additional POST data to be entered into your tables:</p> |
| 147 | |
| 148 | <code> |
| 149 | $this->load->model('post_model');<br /> |
| 150 | <br /> |
| 151 | $this->post_model->update(elements(array('id', 'title', 'content'), $_POST)); |
| 152 | </code> |
| 153 | |
| 154 | <p>This ensures that only the id, title and content fields are sent to be updated.</p> |
Derek Allard | 2067d1a | 2008-11-13 22:59:24 +0000 | [diff] [blame] | 155 | |
| 156 | </div> |
| 157 | <!-- END CONTENT --> |
| 158 | |
| 159 | |
| 160 | <div id="footer"> |
| 161 | <p> |
kenjis | 4c6ceb0 | 2011-04-15 11:35:43 +0900 | [diff] [blame] | 162 | Previous Topic: <a href="../libraries/javascript.html">Javascript Class</a> · |
Derek Allard | 2067d1a | 2008-11-13 22:59:24 +0000 | [diff] [blame] | 163 | <a href="#top">Top of Page</a> · |
| 164 | <a href="../index.html">User Guide Home</a> · |
kenjis | 4c6ceb0 | 2011-04-15 11:35:43 +0900 | [diff] [blame] | 165 | Next Topic: <a href="captcha_helper.html">CAPTCHA Helper</a></p> |
Derek Jones | 898949f | 2011-01-28 07:42:16 -0600 | [diff] [blame] | 166 | <p><a href="http://codeigniter.com">CodeIgniter</a> · Copyright © 2006 - 2011 · <a href="http://ellislab.com/">EllisLab, Inc.</a></p> |
Derek Allard | 2067d1a | 2008-11-13 22:59:24 +0000 | [diff] [blame] | 167 | </div> |
| 168 | |
| 169 | </body> |
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 170 | </html> |