Unitat 5. Els Objectes.
Introducció
La programació Orientada a Objectes és un paradigma de programació que:
- Aprofita els coneixements de la programació Estructurada i de la Modular.
- Afegeix característiques pròpies de programació, com l’encapsulació, l’herència i el polimorfisme. Amb l’objectiu que sigui un tipus de programació que permet ser ampliable, ser adaptable i transportable. Llegir un poc més aquí.
- Afegeix la creació dinàmica d’unitats de memòria que anomenam Objectes.
Els Objectes són Variables.
[cc lang=”javascript”]var person = {firstName:”John”, lastName:”Doe”, age:50, eyeColor:”blue”};[/cc]
ó[cc lang=”javascript”]//codi d’una variable objecte que conté la informació d’una persona.
var person = {
firstName : “John”,
lastName : “Doe”,
age : 50,
eyeColor : “blue”};
[/cc]
Propietats dels Objectes
firstName,
lastName,age,eyeColor
i els seus valors corresponents són “John”,”Doe”, 50 i “blue”.Podem consultar i modificar els valors de les seves propietats.
- Per Consultar als seus valors ho feim mitjançant:
[cc lang=”javascript”]
var a = person.firstName;
alert(a); //mostrarà “John”
[/cc]
- per Modificar un dels seus valors es fa un forma semblant:
[cc lang=”javascript”]
var a = person.firstName;
alert(a); //mostrarà “John”
person.firstName = “Pere”;
alert(person.firstName); //mostrarà “Pere”
[/cc]
Exercici. Propietats d’un Objecte.
Llegeix el següent codi i pensa com canviar-lo per tal que:
- Afegeix la propietat dog amb el valor “Pluto”.
- Canvia el valor de la propietat firstName al teu nom.
- El botó mostri un missatge que posi totes les dades de la persona.
[cc lang=”javascript”]
Creating a JavaScript Object.
[/cc]
*Fes que surti el resultat a la teva pàgina web d’exercicis, a una nova pàgina POO sobre un botó: “Una variable amb Propietats“.
*Pots realitzar l’exercici sobre aquesta pàgina de w3schools.
Fixa´t en l’exercici de la següent secció, el que farem es clau per entendre un objecte. Hi afegirem un Mètode que ens permetrà generar una resposta pròpia de l’objecte.
Mètodes dels Objectes
Un mètode és una propietat que conté una funció que farà alguna cosa sobre l’objecte. Un objecte podrà tenir tant propietats com mètodes:
firstName John
lastName Doe
age 50
eyeColor blue
fullName function() {return this.firstName + ” ” + this.lastName;}
[cc lang=”javascript”]
var person = {
firstName: “John”,
lastName : “Doe”,
id : 5566,
fullName : function() {
return “El nom sencer de Person és + “this.firstName + ” ” + this.lastName;
}
};
//per cridar el mètode fullName()
person.fullName();
[/cc]
Exercici. Afegir mètodes a un Objecte.
*Aquest exercici modifica la variable anterior directament, no se n’ha de fer cap de nova.
Al codi de la variable objecte de l’exercici anterior hi has d’afegir:
- Un mètode “demanaNom()” que demani mitjançant un prompt quin nom té una persona i canvii la variable. Un botó “canvia nom” que cridi aquest mètode.
- Un mètode “retornaNom()” que retorni el nom de la persona mitjançant un return. Crea un botó que dins un alert cridi retornaNom().
- Un mètode “mostraNom()” que mostri el el nom i llinatges d’una persona mitjançant un alert dins del mètode.
[cc]
The JavaScript this Keyword
In this example, this represents the person object.
Because the person object “owns” the fullName method.
[/cc]
Invocació d’un Objecte
El punt clau d’aquest sistema de programació és el que permet que nosaltres creem un tipus d’objecte (una classe d’objecte) i després en podrem fer instanciacions (invocacions de un nou objecte). Hi ha tres formes de crear un nou objecte:
- Definir i crear un objecte simple, declarant-lo com si fos una variable.
- Definir i crear un objecte amb la paraula clau new.
- Definir un objecte constructor i desde ell crear els nous objectes.
Instanciació com a variable.
D’aquesta forma declaram i cream l’objecte tot alhora.La forma ja ha estat estudiada abans i la recordam:
Instanciació emprant la paraula reservada new.
Feim el mateix Objecte que abans:
[cc lang=”Javascript”]
var person = new Object();
person.firstName:”John”;
person.lastName:”Doe”;
person.age:50;
person.eyeColor:”blue”;[/cc]
Instanciació cridant una funció constructora.
Cream una funció que ens construirà un objecte nou.
[cc lang=”javascript”]
function Person(first, last, age, eye) {
this.firstName = first;
this.lastName = last;
this.age = age;
this.eyeColor = eye;
}[/cc]
Quan volem canviar els valors de les propietats d’un objecte ho feim amb el terme this i així es canvia les pròpies propietas de l’objecte.
Aquesta és la forma que emprarem per construir els objectes, ens fixarem amb el següent codi com exemple de com funciona aquesta tècnica.
-
- De la línia 11 a la línia 16 tenim un Constructor de fitxes (objectes) de persones.
- L’objecte formalment, sempre comença en majúscula.
- Els paràmetres que li passam ell els inicialitza a les seves propietats.
- A la línia 19 es crea un objecte persona. Fins ara no existia cap fitxa de persona. Ara sí i té el nom de myFather.
- La línia 22 ens mostra el resultat a un id de html anomenta “demo”.
Exercici. JavaScript Object Constructors
[cc code=”javascript”]
JavaScript Object Constructors
[/cc]
[/cc]
[cc lang=”javascript”]
My First JavaScript
[/cc]
Per introduir aquest paradigma de programació llegirem i comentarem el capítol 4 del llibre EloquentJavascript. Els conceptes que ens mostraran són:
- Conjunts de dades.
- Propietats de les dades.
- Mètodes aplicats a dades.
- Objectes.
- Mutabilitat d’Objectes.
- Recorreguts de llistes de dades. (Arrays).
- Propietats dels Strings.
https://www.cssfontstack.com/Courier-New
http://projects.playables.net/
https://lab.nationalmedals.org/