Share via


JSON-funktion

Gælder for: Lærredapps Modelbaserede apps

Genererer en JSON-tekststreng for en tabel, en post eller en værdi.

Beskrivelse

Funktionen JSON returnerer en JSON-repræsentation (JavaScript Object Notation) af en datastruktur som tekst, så den er egnet til at lagre eller sende på tværs af et netværk. [ECMA-404](https://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdf og IETF RFC 8259 beskriver formatet, som ofte bruges i JavaScript og andre programmeringssprog.

Lærredapps understøtter de datatyper, der vises i denne tabel, med detaljer om deres tekstrepræsentation:

Datatype Beskrivelse Eksempel på resultat
Boolesk værdi true eller false. true
Farve Streng, der indeholder den hexadecimale repræsentation på 8 cifre for farven. Denne repræsentation har formatet #rrggbbaa, hvor rr er den røde komponent, gg er den grønne, bb er den blå, og aa er alfakanalen. For alfakanalen er 00 helt gennemsigtig, og FF er helt uigennemsigtig. Du kan overføre strengen til funktionen ColorValue. "#102030ff"
Valuta Det tal, der bruger den korrekte decimalseparator til brugerens sprog. Videnskabelig notation bruges, hvis det er nødvendigt. 1.345
Dato Streng, der indeholder datoen i ISO 8601 åååå-mm-dd-format. "2019-03-31"
DateTime En streng, der indeholder et ISO 8601 dato/klokkeslæt. Dato/klokkeslætsværdier er i UTC-tid, som slutningen "Z" angiver. "2019-03-31T22:32:06.822Z"
GUID Streng, der indeholder GUID-værdien. Bogstaver er små. "751b58ac-380e-4a04-a925-9f375995cc40"
Billede, medie Hvis JSONFormat.IncludeBinaryData er angivet, er mediefiler kodet i en streng. Webreferencer, der bruger URL-adresseskemaet http: eller https:, ændres ikke. Henvisninger til binære data i hukommelsen kodes med formatet "data:mimetype;Base64,...". Data i hukommelsen inkluderer billeder, som brugerne optager vha. Camera-kontrolelementet, og andre referencer med appres: og blob: URL-adresseskemaer. "..."
Tal Det tal, der bruger den korrekte decimalseparator til brugerens sprog. Videnskabelig notation bruges, hvis det er nødvendigt. 1.345
Grupperet indstilling Numerisk værdi af valget, ikke den etiket, der bruges til visning. Den numeriske værdi bruges, fordi den er uafhængig af sproget. 1001
Klokkeslæt En streng, der indeholder et ISO 8601 TT: mm: SS. FFF-format. "23:12:49.000"
Post Kommasepareret liste, mellem { og }, af felter og deres værdier. Denne notation ligner den, man bruger i poster i lærredapps, men navnet er altid mellem dobbelte anførselstegn. Dette format understøtter ikke poster, der er baseret på mange til én-relationer. { "First Name": "Fred", "Age": 21 }
Table Kommasepareret liste, mellem [ og ], af poster. Dette format understøtter ikke tabeller, der er baseret på en-til-mange-relationer. Brug indstillingen JSONFormat.FlattenValueTables til at fjerne posten for tabeller med enkelt kolonne med kolonnen Værdi. [ { "First Name": "Fred", "Age": 21 }, { "First Name": "Jean", "Age": 20 } ]
To muligheder Boolesk værdi af de to valgmuligheder, sand eller falsk, ikke den etiket, der bruges til visning. Den booleske værdi bruges, fordi den er uafhængig af sproget. false
Link, Tekst Streng mellem dobbelte anførselstegn. Funktionen udruller integrerede dobbelte anførselstegn med en omvendt skråstreg, erstatter linjeskift med "\n" og foretager andre standardudskiftninger af JavaScript. "This is a string."

Angiv det valgfri argument Format for at styre, hvor læsbart resultatet er, og hvordan ikke-understøttede og binære datatyper håndteres. Som standard er outputtet så komprimeret som muligt uden unødvendige mellemrum eller ny linje, og ikke-understøttede datatyper og binære data er ikke tilladt. Du kan kombinere flere formater, hvis du angiver operatoren &.

JSONFormat-optælling Description
JSONFormat.Compact Standard. Outputtet er så komprimeret som muligt uden ekstra mellemrum eller nye linjer.
JSONFormat.FlattenValueTables Som en værditabel resulterer [1,2,3]-notation i en tabel, der indeholder poster, hvor hver post har en enkelt Værdi-kolonne. I JSON repræsenterer den samme notation en matrix med tre tal. For at gøre det nemmere at skelne mellem de to ændrer denne indstilling en Power Fx-værditabel til en JSON-venlig matrix i stedet for en matrix med poster.
JSONFormat.IndentFour Outputtet indeholder en ny linje for hvert kolonne- og indlejringsniveau for at øge læsbarheden, og der bruges fire mellemrum til hvert indrykningsniveau.
JSONFormat.IncludeBinaryData Resultatet inkluderer kolonner med billeder, videoer og lydklip. Dette format kan øge størrelsen af resultatet drastisk og forringe appens ydeevne.
JSONFormat.IgnoreBinaryData Resultatet inkluderer ikke kolonner med billeder, videoer eller lydklip. Hvis du ikke angiver JSONFormat.IncludeBinaryData eller JSONFormat.IgnoreBinaryData, medfører funktionen en fejl, hvis der registreres binære data.
JSONFormat.IgnoreUnsupportedTypes Datatyper, der ikke understøttes, er tilladt, men de medtages ikke i resultatet. Der dannes som standard en fejl i ikke-understøttede datatyper.

Brug funktionerne ShowColumns og DropColumns til at styre, hvilke data resultatet indeholder, og for at fjerne ikke-understøttede datatyper.

Da JSON kan være både hukommelses- og belastningsintensiv, må du kun bruge denne funktion i handlingsfunktioner. Du kan hente resultatet fra JSON til en variabel , som du derefter kan bruge i dataflowet.

Hvis en kolonne har et visningsnavn og et logisk navn, indeholder resultatet det logiske navn. Viste navne afspejler sproget for app-brugeren og er derfor upassende for dataoverførsel til en fælles service.

Syntaks

JSON( DataStructure [, Format ] )

  • DataStructure – påkrævet. Den datastruktur, der skal konverteres til JSON. Tabeller, poster og primitive værdier understøttes og indlejres vilkårligt.
  • Format – valgfrit. JSONFormat-optællingsværdi. Standardværdien er JSONFormat.Compact, hvilket betyder, at der ikke tilføjes nye linjer eller mellemrum, og binære data og kolonner, der ikke understøttes, bliver blokeret.

Eksempler

Hierarkiske data

  1. Indsæt et Button-kontrolelement, og indstil dets OnSelect-egenskab til denne formel.

    ClearCollect( CityPopulations,
        { City: "London",    Country: "United Kingdom", Population: 8615000 },
        { City: "Berlin",    Country: "Germany",        Population: 3562000 },
        { City: "Madrid",    Country: "Spain",          Population: 3165000 },
        { City: "Hamburg",   Country: "Germany",        Population: 1760000 },
        { City: "Barcelona", Country: "Spain",          Population: 1602000 },
        { City: "Munich",    Country: "Germany",        Population: 1494000 }
    );
    ClearCollect( CitiesByCountry, GroupBy( CityPopulations, "Country", "Cities" ) )
    
  2. Vælg knappen, mens du holder Alt-tasten nede.

    Samlingen CitiesByCountry oprettes med denne datastruktur, som du kan få vist ved at vælge Samlinger i menuen Filer og derefter vælge navnet på samlingen.

    Samlingen CitiesByCountry.

    Du kan også få vist denne samling ved at vælge Indstillinger>Kommende funktioner>Aktivere resultatvisningen for formellinjen, vælge navnet på samlingen på formellinjen og derefter vælge pil ned ud for navnet på samlingen under formellinjen.

    Samling på formellinjens resultatvisning.

  3. Indsæt endnu en knap, og indstil dets OnSelect-egenskab til denne formel:

    Set( CitiesByCountryJSON, JSON( CitiesByCountry ) )
    

    Denne formel angiver den globale variabel CitiesByCountryJSON til JSON-repræsentationen for CitiesByCountry.

  4. Vælg knappen, mens du holder Alt-tasten nede.

  5. Indsæt et Label-kontrolelement, og indstil dets Text-egenskab til denne variabel.

    CitiesByCountryJSON
    

    Etiketten viser dette resultat, men alt sammen på en enkelt linje uden mellemrum, som er egnet til overførsel via et netværk:

    [
      {
        "Cities": [{ "City": "London", "Population": 8615000 }],
        "Country": "United Kingdom"
      },
      {
        "Cities": [
          { "City": "Berlin", "Population": 3562000 },
          { "City": "Hamburg", "Population": 1760000 },
          { "City": "Munich", "Population": 1494000 }
        ],
        "Country": "Germany"
      },
      {
        "Cities": [
          { "City": "Madrid", "Population": 3165000 },
          { "City": "Barcelona", "Population": 1602000 }
        ],
        "Country": "Spain"
      }
    ]
    
  6. Skift den anden knaps formel for at gøre outputtet mere læsbart.

    Set( CitiesByCountryJSON, JSON(CitiesByCountry, JSONFormat.IndentFour ))
    
  7. Vælg den anden knap, mens du holder Alt-tasten nede.

    Etiketten viser det mere læsbare resultat.

    [
      {
        "Cities": [
          {
            "City": "London",
            "Population": 8615000
          }
        ],
        "Country": "United Kingdom"
      },
      {
        "Cities": [
          {
            "City": "Berlin",
            "Population": 3562000
          },
          {
            "City": "Hamburg",
            "Population": 1760000
          },
          {
            "City": "Munich",
            "Population": 1494000
          }
        ],
        "Country": "Germany"
      },
      {
        "Cities": [
          {
            "City": "Madrid",
            "Population": 3165000
          },
          {
            "City": "Barcelona",
            "Population": 1602000
          }
        ],
        "Country": "Spain"
      }
    ]
    

Billeder og medier i base64

  1. Tilføj et kontrolelement af typen Image.

    Denne kontrolelement bringer SampleImage til det.

  2. Tilføj et Button-kontrolelement, og indstil dets OnSelect-egenskab til denne formel.

    Set( ImageJSON, JSON( SampleImage, JSONFormat.IncludeBinaryData ) )
    
  3. Vælg knappen, mens du holder Alt-tasten nede.

  4. Tilføj en etiket, og indstil dens Text-egenskab til denne variabel.

    ImageJSON
    
  5. Tilpas størrelsen på kontrolelementet, og formindsk skriftstørrelsen efter behov for at få vist det meste af resultatet.

    Etiketten viser den tekststreng, som JSON-funktionen har hentet.

    ""
    

Værditabeller

Denne formel:

JSON( [1,2,3] )

opretter tekststrengen [{"Værdi":1},{"Værdi":2},{"Værdi":3}].

Den samme formel med indstillingen JSONFormat.FlattenValueTables:

JSON( [1,2,3], JSONFormat.FlattenValueTables )

opretter tekststrengen [1,2,3].

Bemærk, at indstillingen FlattenValueTables ikke har nogen betydning, når du bruger JSON sammen med samlingerne CityPopulations eller CitiesByCountry, da disse tabeller ikke er værditabeller. En værditabel har en enkelt kolonne, og den skal have navnet "Værdi".