1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
|
<?xml version="1.0" encoding="utf-8"?>
<page xmlns="http://projectmallard.org/1.0/" xmlns:its="http://www.w3.org/2005/11/its" xmlns:xi="http://www.w3.org/2001/XInclude" type="guide" style="task" id="entry.js" xml:lang="sv">
<info>
<title type="text">Entry (Javascript)</title>
<link type="guide" xref="beginner.js#entry"/>
<revision version="0.1" date="2012-06-03" status="draft"/>
<credit type="author copyright">
<name>Taryn Fox</name>
<email its:translate="no">jewelfox@fursona.net</email>
<years>2012</years>
</credit>
<desc>Ett textinmatningsfält med en rad</desc>
<mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
<mal:name>Sebastian Rasmussen</mal:name>
<mal:email>sebras@gmail.com</mal:email>
<mal:years>2019</mal:years>
</mal:credit>
<mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
<mal:name>Anders Jonsson</mal:name>
<mal:email>anders.jonsson@norsjovallen.se</mal:email>
<mal:years>2021</mal:years>
</mal:credit>
</info>
<title>Entry</title>
<media type="image" mime="image/png" src="media/entry.png"/>
<p>Detta program hälsar dig med namn genom ett poppuppfönster.</p>
<code mime="application/javascript" style="numbered">#!/usr/bin/gjs
imports.gi.versions.Gtk = '3.0';
const Gio = imports.gi.Gio;
const GLib = imports.gi.GLib;
const Gtk = imports.gi.Gtk;
class EntryExample {
// Skapa programmet i sig
constructor() {
this.application = new Gtk.Application({
application_id: 'org.example.jsentry',
flags: Gio.ApplicationFlags.FLAGS_NONE
});
// Anslut ”activate”- och ”startup”-signaler till återanropsfunktionerna
this.application.connect('activate', this._onActivate.bind(this));
this.application.connect('startup', this._onStartup.bind(this));
}
// Återanropsfunktion för ”activate”-signal visar fönster när den aktiveras
_onActivate() {
this._window.present();
}
// Återanropsfunktion för ”startup”-signal bygger användargränssnittet
_onStartup() {
this._buildUI();
}
// Bygg programmets användargränssnitt
_buildUI() {
// Skapa programfönstret
this._window = new Gtk.ApplicationWindow({
application: this.application,
window_position: Gtk.WindowPosition.CENTER,
default_height: 100,
default_width: 300,
border_width: 10,
title: "Vad heter du?"});
// Skapa textinmatningsrutan
this.entry = new Gtk.Entry ();
this._window.add(this.entry);
// Anslut textinmatningsrutan till en funktion som svarar på det du skriver in
this.entry.connect("activate", this._hello.bind(this));
// Visa fönstret och alla barnkomponenter
this._window.show_all();
}
_hello() {
// Skapa en poppuppdialog som hälsar personen som skriver in sitt namn
this._greeter = new Gtk.MessageDialog ({
transient_for: this._window,
modal: true,
text: "Hej " + this.entry.get_text() + "!",
message_type: Gtk.MessageType.OTHER,
buttons: Gtk.ButtonsType.OK,
});
// Visa poppuppdialogen
this._greeter.show();
// Bind OK-knappen till funktionen som stänger poppuppen
this._greeter.connect ("response", this._okClicked.bind(this));
}
_okClicked() {
this._greeter.destroy();
}
};
// Kör programmet
let app = new EntryExample ();
app.application.run (ARGV);
</code>
<p>I detta exempel använde vi följande:</p>
<list>
<item><p><link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.Application.html">Gtk.Application</link></p></item>
<item><p><link href="http://developer.gnome.org/gtk3/stable/GtkApplicationWindow.html">Gtk.ApplicationWindow</link></p></item>
<item><p><link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.Entry.html">Gtk.Entry</link></p></item>
<item><p><link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.MessageDialog.html">Gtk.MessageDialog</link></p></item>
</list>
</page>
|