Torna indietro   Hardware Upgrade Forum > Software > Programmazione

WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-11-2010, 22:26   #1
lucausa75
Senior Member
 
L'Avatar di lucausa75
 
Iscritto dal: Jun 2001
Città: Catania
Messaggi: 2696
[VB2010] - Associare a variabile un DataGridView

Salve ragazzi,

a livello di form ho dichiarato queste variabili:

Codice:
    Dim MyDB As String = "Biblio.mdb"
    Dim MyPW As String = ""
    Dim MyTB As String = "Elenco Libri"
Successivamente ho creato anche una SUB tramite la quale mi connetto ad un database:

Codice:
Private Sub EseguiConnessione(ByVal DB As String, ByVal PW As String, ByVal TB As String, ByVal DGV As DataGridView)
Quì in basso trovate come la richiamo a livello di programma:

Codice:
EseguiConnessione(MyDB, MyPW, MyTB, dgvArchivio)
Voglio capire come dichiarare la variabile DataGridView per associarla alla griglia chiamata dgvArchivio e realizzare qualcosa del tipo:

Codice:
EseguiConnessione(MyDB, MyPW, MyTB, MyDGV)
e quindi dichiarare MyDGV ad esempio così:

Codice:
Dim MyDGV As DataGridView = dgvArchivio
ma non mi funziona...

Alle volte rimpiago il buon VB6
lucausa75 è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2010, 08:15   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Ma come VARIABILE ?!

Con tutto quello che ho speso per farti studiare...

Il DGV è un OGGETTO.
Se vai ad aprire il file ".Designer.vb" di una Form, che contiene tutto il codice generato da VS su operazioni eseguite in design, vedrai che :
Codice:
Private Sub InitializeComponent()
        ...
        Me.DGV = New System.Windows.Forms.DataGridView
        ...
Quindi il DGV aggiunto in design è già istanziato, non c'è nessun bisogno di creare un nuovo oggetto che è uguale-a-DGV...
E pertanto lo puoi passare direttamente in argomento ai Metodi che vuoi...

Ma ci vuole tempo e pazienza : il modo di pensare alla-VB6 ti perseguiterà ancora per un bel pezzo...
__________________
Contattami su FaceBook --> [ ::: MarcoGG su FaceBook ::: ]
Visita il mio Blog --> [ ::: Il Blog di MarcoGG ::: ]
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2010, 08:56   #3
lucausa75
Senior Member
 
L'Avatar di lucausa75
 
Iscritto dal: Jun 2001
Città: Catania
Messaggi: 2696
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Ma come VARIABILE ?!

Con tutto quello che ho speso per farti studiare...

Il DGV è un OGGETTO.
Se vai ad aprire il file ".Designer.vb" di una Form, che contiene tutto il codice generato da VS su operazioni eseguite in design, vedrai che :
Codice:
Private Sub InitializeComponent()
        ...
        Me.DGV = New System.Windows.Forms.DataGridView
        ...
Quindi il DGV aggiunto in design è già istanziato, non c'è nessun bisogno di creare un nuovo oggetto che è uguale-a-DGV...
E pertanto lo puoi passare direttamente in argomento ai Metodi che vuoi...

Ma ci vuole tempo e pazienza : il modo di pensare alla-VB6 ti perseguiterà ancora per un bel pezzo...
...variabile nel senso che in un progetto DGV si può chiamare dgvArchivio e in un altro dgvLista...

Quindi se uso la mia sub

Codice:
EseguiConnessione(MyDB, MyPW, MyTB, XX)
nel progetto A dovrò dire a EseguiConnessione di inserire i dati dentro dgvArchivio (XX sarà dgvArchivio) mentre se la uso nel progetto B dovrò dire di mettere i dati dentro dgvLista (XX sarà dgvArchivio)...

Discorso tortuoso?
Grazie Marco...
lucausa75 è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2010, 09:04   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da lucausa75 Guarda i messaggi
Quindi se uso la mia sub

Codice:
EseguiConnessione(MyDB, MyPW, MyTB, XX)
nel progetto A dovrò dire a EseguiConnessione di inserire i dati dentro dgvArchivio (XX sarà dgvArchivio) mentre se la uso nel progetto B dovrò dire di mettere i dati dentro dgvLista (XX sarà dgvArchivio)...

Discorso tortuoso?
Grazie Marco...
No, va tutto bene...
__________________
Contattami su FaceBook --> [ ::: MarcoGG su FaceBook ::: ]
Visita il mio Blog --> [ ::: Il Blog di MarcoGG ::: ]
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2010, 11:01   #5
lucausa75
Senior Member
 
L'Avatar di lucausa75
 
Iscritto dal: Jun 2001
Città: Catania
Messaggi: 2696
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
No, va tutto bene...
...però avendo questa sub
Codice:
EseguiConnessione(MyDB, MyPW, MyTB, XX)
e definendola così
Codice:
EseguiConnessione(MyDB, MyPW, MyTB, dgvArchivio)
ricevo un bell'errore

Come ho fatto per queste variabili

Codice:
    Dim MyDB As String = "Biblio.mdb"
    Dim MyPW As String = ""
    Dim MyTB As String = "Elenco Libri"
pensavo ci fosse una cosa simile per la DatGridView per evitare di andare a scivere ogni volta ed n volte il nome della griglia.

Volevo scriverlo una sola volta e a monte del form...

Ultima modifica di lucausa75 : 27-11-2010 alle 11:03.
lucausa75 è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2010, 13:06   #6
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Anzitutto se stai scrivendo un Metodo ( in VB.NET le Sub e le Function sono METODI di una classe ), quella firma è da evitare :

Codice:
Private Sub popolaDGV(ByVal MyDB As String, ByVal MyPW As String, ByVal MyTB As String, ByVal dgv As DataGridView)
In secondo luogo, se poi vuoi anche USARLO, quel metodo, è ovvio che gli devi passare il nome dell'oggetto dgv :
Codice:
    Private Sub popolaDGV(ByVal MyDB As String, ByVal MyPW As String, ByVal MyTB As String, ByVal dgv As DataGridView)

        Dim cnString As String = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & MyDB & ";Jet OLEDB:Database Password=" & MyPW & ";"
        Dim sqlSelect As String = "SELECT * FROM " & MyTB
        Dim conn As New OleDb.OleDbConnection(cnString)
        Dim DAdptr As New OleDb.OleDbDataAdapter(sqlSelect, conn)
        Dim Dtbl As New DataTable
        DAdptr.Fill(Dtbl)
        dgv.DataSource = Dtbl

    End Sub
E ad esempio la utilizzo con :

Codice:
    Private Sub cmd_popola_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmd_popola.Click

        popolaDGV(percorso & nomeDB, "", "nomeTabella", DataGridView1)

    End Sub
Nessun errore.
Non capisco dove stia il problema.
__________________
Contattami su FaceBook --> [ ::: MarcoGG su FaceBook ::: ]
Visita il mio Blog --> [ ::: Il Blog di MarcoGG ::: ]
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
Nutanix accelera la migrazione da VMware...
Nutanix apre ai neocloud: piattaforma mu...
Nutanix amplia la piattaforma cloud e st...
Le fotografie dell'eclissi solare e dell...
Oracle AI Database si potenzia con nuove...
Russia offline: blackout internet mobile...
Gemini, Google investe 30 milioni per la...
Roborock Qrevo Edge S5A: 17.000 Pa, acqu...
Resa pubblica la foto della ''Terra che ...
Il robot che ha piegato 200 scatole di f...
SteelSeries Aerox 3 Wireless Gen 2: nuov...
"Quasi sociopatico": Sam Altma...
Star Wars Eclipse in difficoltà: ...
Gestione del team e romance organiche: l...
Intel lancia Core Ultra X9 378H: hardwar...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 21:00.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v