JSPM

  • Created
  • Published
  • Downloads 274
  • Score
    100M100P100Q95803F
  • License MIT

Package Exports

  • ldflex

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (ldflex) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

LDflex makes Linked Data in JavaScript fun

LDflex is a domain-specific language for JavaScript that lets you traverse Linked Data graphs like dynamic objects.

You can write things like person.friends.firstName to get a list of your friends. Thanks to the power of JSON-LD contexts and JavaScript's Proxy, these properties are not hard-coded in LDflex and can be chosen at runtime.

Tim Berners-Lee came up with the idea for such a fluid JavaScript interface to Linked Data, in a discussion on how to make Linked Data easier for developers.

Installation

npm install ldflex

In order to execute queries, you will also need a query engine:

npm install ldflex-comunica

Usage

When you have obtained a starting subject, you can navigate through its properties using standard JavaScript dot property syntax.

In order to query for the result, use await if you want a single value, or for await to iterate over all values.

Initialization

const { QueryPathFactory } = require('ldflex');
const { default: ComunicaEngine } = require('ldflex-comunica');

// The JSON-LD context for resolving properties
const context = {
  "@context": {
    "@vocab": "http://xmlns.com/foaf/0.1/",
    "friends": "knows",
    "label": "http://www.w3.org/2000/01/rdf-schema#label",
  }
};
// The query engine and its source
const queryEngine = new ComunicaEngine('https://ruben.verborgh.org/profile/');
// The object that can create new paths
const path = new QueryPathFactory({ context, queryEngine });

Looking up data on the Web

const ruben = path.create({ subject: 'https://ruben.verborgh.org/profile/#me' });
showPerson(ruben);

async function showPerson(person) {
  console.log(`This person is ${await person.name}`);

  console.log(`${await person.givenName} is interested in:`);
  for await (const name of person.interest.label)
    console.log(`- ${name}`);

  console.log(`${await person.givenName} is friends with:`);
  for await (const name of person.friends.givenName)
    console.log(`- ${name}`);
}

Inspecting the generated path expression

(async person => {
  console.log(await person.friends.givenName.pathExpression);
})(ruben);

Converting into a SPARQL query

(async person => {
  console.log(await person.friends.givenName.sparql);
})(ruben);

License

©2018–present Ruben Verborgh, MIT License.